<!--{{{-->
<link rel='alternate' type='application/rss+xml' title='RSS' href='index.xml' />
<!--}}}-->
Background: #fff
Foreground: #000
PrimaryPale: #8cf
PrimaryLight: #18f
PrimaryMid: #04b
PrimaryDark: #014
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
/*{{{*/
body {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}

a {color:[[ColorPalette::PrimaryMid]];}
a:hover {background-color:[[ColorPalette::PrimaryMid]]; color:[[ColorPalette::Background]];}
a img {border:0;}

h1,h2,h3,h4,h5,h6 {color:[[ColorPalette::SecondaryDark]]; background:transparent;}
h1 {border-bottom:2px solid [[ColorPalette::TertiaryLight]];}
h2,h3 {border-bottom:1px solid [[ColorPalette::TertiaryLight]];}

.button {color:[[ColorPalette::PrimaryDark]]; border:1px solid [[ColorPalette::Background]];}
.button:hover {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::SecondaryLight]]; border-color:[[ColorPalette::SecondaryMid]];}
.button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::SecondaryDark]];}

.header {background:[[ColorPalette::PrimaryMid]];}
.headerShadow {color:[[ColorPalette::Foreground]];}
.headerShadow a {font-weight:normal; color:[[ColorPalette::Foreground]];}
.headerForeground {color:[[ColorPalette::Background]];}
.headerForeground a {font-weight:normal; color:[[ColorPalette::PrimaryPale]];}

.tabSelected{color:[[ColorPalette::PrimaryDark]];
	background:[[ColorPalette::TertiaryPale]];
	border-left:1px solid [[ColorPalette::TertiaryLight]];
	border-top:1px solid [[ColorPalette::TertiaryLight]];
	border-right:1px solid [[ColorPalette::TertiaryLight]];
}
.tabUnselected {color:[[ColorPalette::Background]]; background:[[ColorPalette::TertiaryMid]];}
.tabContents {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::TertiaryPale]]; border:1px solid [[ColorPalette::TertiaryLight]];}
.tabContents .button {border:0;}

#sidebar {}
#sidebarOptions input {border:1px solid [[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel {background:[[ColorPalette::PrimaryPale]];}
#sidebarOptions .sliderPanel a {border:none;color:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:hover {color:[[ColorPalette::Background]]; background:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:active {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::Background]];}

.wizard {background:[[ColorPalette::PrimaryPale]]; border:1px solid [[ColorPalette::PrimaryMid]];}
.wizard h1 {color:[[ColorPalette::PrimaryDark]]; border:none;}
.wizard h2 {color:[[ColorPalette::Foreground]]; border:none;}
.wizardStep {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];
	border:1px solid [[ColorPalette::PrimaryMid]];}
.wizardStep.wizardStepDone {background:[[ColorPalette::TertiaryLight]];}
.wizardFooter {background:[[ColorPalette::PrimaryPale]];}
.wizardFooter .status {background:[[ColorPalette::PrimaryDark]]; color:[[ColorPalette::Background]];}
.wizard .button {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryLight]]; border: 1px solid;
	border-color:[[ColorPalette::SecondaryPale]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryPale]];}
.wizard .button:hover {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Background]];}
.wizard .button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::Foreground]]; border: 1px solid;
	border-color:[[ColorPalette::PrimaryDark]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryDark]];}

.wizard .notChanged {background:transparent;}
.wizard .changedLocally {background:#80ff80;}
.wizard .changedServer {background:#8080ff;}
.wizard .changedBoth {background:#ff8080;}
.wizard .notFound {background:#ffff80;}
.wizard .putToServer {background:#ff80ff;}
.wizard .gotFromServer {background:#80ffff;}

#messageArea {border:1px solid [[ColorPalette::SecondaryMid]]; background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]];}
#messageArea .button {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::SecondaryPale]]; border:none;}

.popupTiddler {background:[[ColorPalette::TertiaryPale]]; border:2px solid [[ColorPalette::TertiaryMid]];}

.popup {background:[[ColorPalette::TertiaryPale]]; color:[[ColorPalette::TertiaryDark]]; border-left:1px solid [[ColorPalette::TertiaryMid]]; border-top:1px solid [[ColorPalette::TertiaryMid]]; border-right:2px solid [[ColorPalette::TertiaryDark]]; border-bottom:2px solid [[ColorPalette::TertiaryDark]];}
.popup hr {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::PrimaryDark]]; border-bottom:1px;}
.popup li.disabled {color:[[ColorPalette::TertiaryMid]];}
.popup li a, .popup li a:visited {color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:active {background:[[ColorPalette::SecondaryPale]]; color:[[ColorPalette::Foreground]]; border: none;}
.popupHighlight {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
.listBreak div {border-bottom:1px solid [[ColorPalette::TertiaryDark]];}

.tiddler .defaultCommand {font-weight:bold;}

.shadow .title {color:[[ColorPalette::TertiaryDark]];}

.title {color:[[ColorPalette::SecondaryDark]];}
.subtitle {color:[[ColorPalette::TertiaryDark]];}

.toolbar {color:[[ColorPalette::PrimaryMid]];}
.toolbar a {color:[[ColorPalette::TertiaryLight]];}
.selected .toolbar a {color:[[ColorPalette::TertiaryMid]];}
.selected .toolbar a:hover {color:[[ColorPalette::Foreground]];}

.tagging, .tagged {border:1px solid [[ColorPalette::TertiaryPale]]; background-color:[[ColorPalette::TertiaryPale]];}
.selected .tagging, .selected .tagged {background-color:[[ColorPalette::TertiaryLight]]; border:1px solid [[ColorPalette::TertiaryMid]];}
.tagging .listTitle, .tagged .listTitle {color:[[ColorPalette::PrimaryDark]];}
.tagging .button, .tagged .button {border:none;}

.footer {color:[[ColorPalette::TertiaryLight]];}
.selected .footer {color:[[ColorPalette::TertiaryMid]];}

.error, .errorButton {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Error]];}
.warning {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryPale]];}
.lowlight {background:[[ColorPalette::TertiaryLight]];}

.zoomer {background:none; color:[[ColorPalette::TertiaryMid]]; border:3px solid [[ColorPalette::TertiaryMid]];}

.imageLink, #displayArea .imageLink {background:transparent;}

.annotation {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border:2px solid [[ColorPalette::SecondaryMid]];}

.viewer .listTitle {list-style-type:none; margin-left:-2em;}
.viewer .button {border:1px solid [[ColorPalette::SecondaryMid]];}
.viewer blockquote {border-left:3px solid [[ColorPalette::TertiaryDark]];}

.viewer table, table.twtable {border:2px solid [[ColorPalette::TertiaryDark]];}
.viewer th, .viewer thead td, .twtable th, .twtable thead td {background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::Background]];}
.viewer td, .viewer tr, .twtable td, .twtable tr {border:1px solid [[ColorPalette::TertiaryDark]];}

.viewer pre {border:1px solid [[ColorPalette::SecondaryLight]]; background:[[ColorPalette::SecondaryPale]];}
.viewer code {color:[[ColorPalette::SecondaryDark]];}
.viewer hr {border:0; border-top:dashed 1px [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::TertiaryDark]];}

.highlight, .marked {background:[[ColorPalette::SecondaryLight]];}

.editor input {border:1px solid [[ColorPalette::PrimaryMid]];}
.editor textarea {border:1px solid [[ColorPalette::PrimaryMid]]; width:100%;}
.editorFooter {color:[[ColorPalette::TertiaryMid]];}
.readOnly {background:[[ColorPalette::TertiaryPale]];}

#backstageArea {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::TertiaryMid]];}
#backstageArea a {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstageArea a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; }
#backstageArea a.backstageSelTab {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
#backstageButton a {background:none; color:[[ColorPalette::Background]]; border:none;}
#backstageButton a:hover {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstagePanel {background:[[ColorPalette::Background]]; border-color: [[ColorPalette::Background]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]];}
.backstagePanelFooter .button {border:none; color:[[ColorPalette::Background]];}
.backstagePanelFooter .button:hover {color:[[ColorPalette::Foreground]];}
#backstageCloak {background:[[ColorPalette::Foreground]]; opacity:0.6; filter:alpha(opacity=60);}
/*}}}*/
/*{{{*/
* html .tiddler {height:1%;}

body {font-size:.75em; font-family:arial,helvetica; margin:0; padding:0;}

h1,h2,h3,h4,h5,h6 {font-weight:bold; text-decoration:none;}
h1,h2,h3 {padding-bottom:1px; margin-top:1.2em;margin-bottom:0.3em;}
h4,h5,h6 {margin-top:1em;}
h1 {font-size:1.35em;}
h2 {font-size:1.25em;}
h3 {font-size:1.1em;}
h4 {font-size:1em;}
h5 {font-size:.9em;}

hr {height:1px;}

a {text-decoration:none;}

dt {font-weight:bold;}

ol {list-style-type:decimal;}
ol ol {list-style-type:lower-alpha;}
ol ol ol {list-style-type:lower-roman;}
ol ol ol ol {list-style-type:decimal;}
ol ol ol ol ol {list-style-type:lower-alpha;}
ol ol ol ol ol ol {list-style-type:lower-roman;}
ol ol ol ol ol ol ol {list-style-type:decimal;}

.txtOptionInput {width:11em;}

#contentWrapper .chkOptionInput {border:0;}

.externalLink {text-decoration:underline;}

.indent {margin-left:3em;}
.outdent {margin-left:3em; text-indent:-3em;}
code.escaped {white-space:nowrap;}

.tiddlyLinkExisting {font-weight:bold;}
.tiddlyLinkNonExisting {font-style:italic;}

/* the 'a' is required for IE, otherwise it renders the whole tiddler in bold */
a.tiddlyLinkNonExisting.shadow {font-weight:bold;}

#mainMenu .tiddlyLinkExisting,
	#mainMenu .tiddlyLinkNonExisting,
	#sidebarTabs .tiddlyLinkNonExisting {font-weight:normal; font-style:normal;}
#sidebarTabs .tiddlyLinkExisting {font-weight:bold; font-style:normal;}

.header {position:relative;}
.header a:hover {background:transparent;}
.headerShadow {position:relative; padding:4.5em 0 1em 1em; left:-1px; top:-1px;}
.headerForeground {position:absolute; padding:4.5em 0 1em 1em; left:0; top:0;}

.siteTitle {font-size:3em;}
.siteSubtitle {font-size:1.2em;}

#mainMenu {position:absolute; left:0; width:10em; text-align:right; line-height:1.6em; padding:1.5em 0.5em 0.5em 0.5em; font-size:1.1em;}

#sidebar {position:absolute; right:3px; width:16em; font-size:.9em;}
#sidebarOptions {padding-top:0.3em;}
#sidebarOptions a {margin:0 0.2em; padding:0.2em 0.3em; display:block;}
#sidebarOptions input {margin:0.4em 0.5em;}
#sidebarOptions .sliderPanel {margin-left:1em; padding:0.5em; font-size:.85em;}
#sidebarOptions .sliderPanel a {font-weight:bold; display:inline; padding:0;}
#sidebarOptions .sliderPanel input {margin:0 0 0.3em 0;}
#sidebarTabs .tabContents {width:15em; overflow:hidden;}

.wizard {padding:0.1em 1em 0 2em;}
.wizard h1 {font-size:2em; font-weight:bold; background:none; padding:0; margin:0.4em 0 0.2em;}
.wizard h2 {font-size:1.2em; font-weight:bold; background:none; padding:0; margin:0.4em 0 0.2em;}
.wizardStep {padding:1em 1em 1em 1em;}
.wizard .button {margin:0.5em 0 0; font-size:1.2em;}
.wizardFooter {padding:0.8em 0.4em 0.8em 0;}
.wizardFooter .status {padding:0 0.4em; margin-left:1em;}
.wizard .button {padding:0.1em 0.2em;}

#messageArea {position:fixed; top:2em; right:0; margin:0.5em; padding:0.5em; z-index:2000; _position:absolute;}
.messageToolbar {display:block; text-align:right; padding:0.2em;}
#messageArea a {text-decoration:underline;}

.tiddlerPopupButton {padding:0.2em;}
.popupTiddler {position: absolute; z-index:300; padding:1em; margin:0;}

.popup {position:absolute; z-index:300; font-size:.9em; padding:0; list-style:none; margin:0;}
.popup .popupMessage {padding:0.4em;}
.popup hr {display:block; height:1px; width:auto; padding:0; margin:0.2em 0;}
.popup li.disabled {padding:0.4em;}
.popup li a {display:block; padding:0.4em; font-weight:normal; cursor:pointer;}
.listBreak {font-size:1px; line-height:1px;}
.listBreak div {margin:2px 0;}

.tabset {padding:1em 0 0 0.5em;}
.tab {margin:0 0 0 0.25em; padding:2px;}
.tabContents {padding:0.5em;}
.tabContents ul, .tabContents ol {margin:0; padding:0;}
.txtMainTab .tabContents li {list-style:none;}
.tabContents li.listLink { margin-left:.75em;}

#contentWrapper {display:block;}
#splashScreen {display:none;}

#displayArea {margin:1em 17em 0 14em;}

.toolbar {text-align:right; font-size:.9em;}

.tiddler {padding:1em 1em 0;}

.missing .viewer,.missing .title {font-style:italic;}

.title {font-size:1.6em; font-weight:bold;}

.missing .subtitle {display:none;}
.subtitle {font-size:1.1em;}

.tiddler .button {padding:0.2em 0.4em;}

.tagging {margin:0.5em 0.5em 0.5em 0; float:left; display:none;}
.isTag .tagging {display:block;}
.tagged {margin:0.5em; float:right;}
.tagging, .tagged {font-size:0.9em; padding:0.25em;}
.tagging ul, .tagged ul {list-style:none; margin:0.25em; padding:0;}
.tagClear {clear:both;}

.footer {font-size:.9em;}
.footer li {display:inline;}

.annotation {padding:0.5em; margin:0.5em;}

* html .viewer pre {width:99%; padding:0 0 1em 0;}
.viewer {line-height:1.4em; padding-top:0.5em;}
.viewer .button {margin:0 0.25em; padding:0 0.25em;}
.viewer blockquote {line-height:1.5em; padding-left:0.8em;margin-left:2.5em;}
.viewer ul, .viewer ol {margin-left:0.5em; padding-left:1.5em;}

.viewer table, table.twtable {border-collapse:collapse; margin:0.8em 1.0em;}
.viewer th, .viewer td, .viewer tr,.viewer caption,.twtable th, .twtable td, .twtable tr,.twtable caption {padding:3px;}
table.listView {font-size:0.85em; margin:0.8em 1.0em;}
table.listView th, table.listView td, table.listView tr {padding:0 3px 0 3px;}

.viewer pre {padding:0.5em; margin-left:0.5em; font-size:1.2em; line-height:1.4em; overflow:auto;}
.viewer code {font-size:1.2em; line-height:1.4em;}

.editor {font-size:1.1em;}
.editor input, .editor textarea {display:block; width:100%; font:inherit;}
.editorFooter {padding:0.25em 0; font-size:.9em;}
.editorFooter .button {padding-top:0; padding-bottom:0;}

.fieldsetFix {border:0; padding:0; margin:1px 0px;}

.zoomer {font-size:1.1em; position:absolute; overflow:hidden;}
.zoomer div {padding:1em;}

* html #backstage {width:99%;}
* html #backstageArea {width:99%;}
#backstageArea {display:none; position:relative; overflow: hidden; z-index:150; padding:0.3em 0.5em;}
#backstageToolbar {position:relative;}
#backstageArea a {font-weight:bold; margin-left:0.5em; padding:0.3em 0.5em;}
#backstageButton {display:none; position:absolute; z-index:175; top:0; right:0;}
#backstageButton a {padding:0.1em 0.4em; margin:0.1em;}
#backstage {position:relative; width:100%; z-index:50;}
#backstagePanel {display:none; z-index:100; position:absolute; width:90%; margin-left:3em; padding:1em;}
.backstagePanelFooter {padding-top:0.2em; float:right;}
.backstagePanelFooter a {padding:0.2em 0.4em;}
#backstageCloak {display:none; z-index:20; position:absolute; width:100%; height:100px;}

.whenBackstage {display:none;}
.backstageVisible .whenBackstage {display:block;}
/*}}}*/
/***
StyleSheet for use when a translation requires any css style changes.
This StyleSheet can be used directly by languages such as Chinese, Japanese and Korean which need larger font sizes.
***/
/*{{{*/
body {font-size:0.8em;}
#sidebarOptions {font-size:1.05em;}
#sidebarOptions a {font-style:normal;}
#sidebarOptions .sliderPanel {font-size:0.95em;}
.subtitle {font-size:0.8em;}
.viewer table.listView {font-size:0.95em;}
/*}}}*/
/*{{{*/
@media print {
#mainMenu, #sidebar, #messageArea, .toolbar, #backstageButton, #backstageArea {display: none !important;}
#displayArea {margin: 1em 1em 0em;}
noscript {display:none;} /* Fixes a feature in Firefox 1.5.0.2 where print preview displays the noscript content */
}
/*}}}*/
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<div class='headerShadow'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
<div class='headerForeground'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
</div>
<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
<div id='sidebar'>
<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>
<div id='sidebarTabs' refresh='content' force='true' tiddler='SideBarTabs'></div>
</div>
<div id='displayArea'>
<div id='messageArea'></div>
<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->
<!--{{{-->
<div class='toolbar' macro='toolbar [[ToolbarCommands::ViewToolbar]]'></div>
<div class='title' macro='view title'></div>
<div class='subtitle'><span macro='view modifier link'></span>, <span macro='view modified date'></span> (<span macro='message views.wikified.createdPrompt'></span> <span macro='view created date'></span>)</div>
<div class='tagging' macro='tagging'></div>
<div class='tagged' macro='tags'></div>
<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
<!--}}}-->
<!--{{{-->
<div class='toolbar' macro='toolbar [[ToolbarCommands::EditToolbar]]'></div>
<div class='title' macro='view title'></div>
<div class='editor' macro='edit title'></div>
<div macro='annotations'></div>
<div class='editor' macro='edit text'></div>
<div class='editor' macro='edit tags'></div><div class='editorFooter'><span macro='message views.editor.tagPrompt'></span><span macro='tagChooser excludeLists'></span></div>
<!--}}}-->
To get started with this blank [[TiddlyWiki]], you'll need to modify the following tiddlers:
* [[SiteTitle]] & [[SiteSubtitle]]: The title and subtitle of the site, as shown above (after saving, they will also appear in the browser title bar)
* [[MainMenu]]: The menu (usually on the left)
* [[DefaultTiddlers]]: Contains the names of the tiddlers that you want to appear when the TiddlyWiki is opened
You'll also need to enter your username for signing your edits: <<option txtUserName>>
These [[InterfaceOptions]] for customising [[TiddlyWiki]] are saved in your browser

Your username for signing your edits. Write it as a [[WikiWord]] (eg [[JoeBloggs]])

<<option txtUserName>>
<<option chkSaveBackups>> [[SaveBackups]]
<<option chkAutoSave>> [[AutoSave]]
<<option chkRegExpSearch>> [[RegExpSearch]]
<<option chkCaseSensitiveSearch>> [[CaseSensitiveSearch]]
<<option chkAnimate>> [[EnableAnimations]]

----
Also see [[AdvancedOptions]]
<<importTiddlers>>






The tiddler 'New Tiddler' doesn't yet exist. Double-click to create it






Field {{{"sort.with.spaces"}}}: <<view "sort.with.spaces">>
Field {{{"sort.withoutspaces"}}}: <<view "sort.withoutspaces">>
This ~TiddlyWiki uses http://FreeStyle-emastic.tiddlyspot.com as a basis, to start with a [[FreeStyle|http://FreeStyle.tiddlysopt.com]] theme. I added some plugins, and StyleSheet adjustments as a minimum working configuration.

Learn more about ~TiddlyWiki at: http://TiddlyWiki.com
/***
|''Name''|AddNowCommand|
|''Description''|Opens a tiddler in edit mode and adds "Date and Time" at the end of the text.|
|''Authors''|see Related to|
|''Version''|0.0.3|
|''Date''|2011-06-10|
|''Status''|@@beta@@|
|''Source''|http://hoster.peermore.com/recipes/TeamWork/tiddlers.wiki#AddNowCommand|
|''License''|BSD|
|''CoreVersion''|2.5|
|''Related to''|http://groups.google.com/group/tiddlywiki/browse_thread/thread/9f3fb012e80fdc4|
|''Keywords''|toolbar command add date time edit|
!!!Description
<<<
To use this new toolbar command you have to add {{{addNow}}} to ToolbarCommands tiddler
eg:
{{{
|~ViewToolbar|tagSearch addNow +editTiddler  ...
}}}
<<<
!!!Date Format
<<<
Possible date formats can be seen at [[TiddlyWiki.org|http://tiddlywiki.org/#%5b%5bDate%20Formats%5d%5d]]

To change the date format add the following line to a tiddler eg: [[zzConfig]] tagged systemConfig
//{{{
config.commands.addNow.dateFormat = 'YYYY-0MM-0DD 0hh:0mm';
//}}}
To change the insert {{{mode}}} add:
//{{{
config.commands.addNow.mode = 'post';
//}}}
To change the {{{selectedText}}} in mode = 'pre' add:
//{{{
config.commands.addNow.selectedText = 'your text here';
//}}}

<<<
!!!Code
***/
//{{{
// selectRange function borrowed from:
// http://stackoverflow.com/questions/499126/jquery-set-cursor-position-in-text-area/841121#841121
// $('#elem').selectRange(3,5);
jQuery.fn.selectRange = function(start, end) {
    return this.each(function() {
        if (this.setSelectionRange) {
            this.focus();
            this.setSelectionRange(start, end);
        } else if (this.createTextRange) {
            var range = this.createTextRange();
            range.collapse(true);
            range.moveEnd('character', end);
            range.moveStart('character', start);
            range.select();
        }
    });
};

config.commands.addNow = {
	text: "addNow",
	tooltip: "Edit tiddler and add [Date & Time]!",
	selectedText: "insert text",

	mode: 'pre',	// 'pre' or 'post'
	spacingText: '\n\n----\n',
	insertText: '[%0]\n',

	dateFormat: 'YYYY-0MM-0DD 0hh:0mm',

	isEnabled: function(tiddler) {
		return (!readOnly && !tiddler.isTagged('systemConfig'));
	}
};

config.commands.addNow.handler = function(event,src,title)
{
	config.commands.editTiddler.handler.call(this,event,src,title); 

	var text = jQuery(story.getTiddler(title)).find('textarea[edit=text]');
	var spacer = text.val() ? this.spacingText : '' ;
	var dynText = this.insertText.format([new Date().formatString(this.dateFormat)]);
	
	if (this.mode == 'post') {
		text.val(text.val() + spacer + dynText);
	}
	else {
		text.val(dynText + this.selectedText + spacer + text.val() );
		jQuery(text).selectRange(dynText.length, dynText.length + this.selectedText.length);
	}
	return false;
};
//}}}
Field {{{"sort.with.spaces"}}}: <<view "sort.with.spaces">>
Field {{{"sort.withoutspaces"}}}: <<view "sort.withoutspaces">>
<<slider chkSliderSideBarTabs SideBarTabs "Index ยป" "display the timeline">>
[tag[default]]
/*{{{*/
.dpfr{float:right;}
/*}}}*/
/***
!Description

!CSS
***/
/*{{{*/
.main{position:relative;}
.lf0,.lf5,.lf10,.lf15,.lf20,.lf25,.lf30,.lf35,.lf40,.lf45,.lf50,.lf55,.lf60,.lf65,.lf70,.lf75,.lf80,.lf85,.lfn5,.lfn10,.lfn15,.lfn20,.lfn25,.lfn30,
.tp0,.tp5,.tp10,.tp15,.tp20,.tp25,.tp30,.tp35,.tp40,.tp45,.tp50,
.bt0,.bt5,.bt10,.bt15,.bt20,.bt25,.bt30,.bt35,.bt40,.bt45,.bt50,
.rtn5,.rtn10,.rtn20,.rtn30{position:absolute;}
.lf0{left:0em;}
.lf5{left:5em;}
.lf10{left:10em;}
.lf15{left:15em;}
.lf20{left:20em;}
.lf25{left:25em;}
.lf30{left:30em;}
.lf35{left:35em;}
.lf40{left:40em;}
.lf45{left:45em;}
.lf50{left:50em;}
.lf55{left:55em;}
.lf60{left:60em;}
.lf65{left:65em;}
.lf70{left:70em;}
.lf75{left:75em;}
.lf80{left:80em;}
.lf85{left:85em;}
.lfn5{left:-5em;}
.lfn10{left:-10em;}
.lfn15{left:-15em;}
.lfn20{left:-20em;}
.lfn25{left:-25em;}
.lfn30{left:-30em;}

.rtn5{right:-5em;}
.rtn10{right:-10em;}
.rtn15{right:-15em;}
.rtn20{right:-20em;}
.rtn25{right:-25em;}
.rtn30{right:-30em;}

.tp0{top:0em;}
.tp5{top:5em;}
.tp10{top:10em;}
.tp15{top:15em;}
.tp20{top:20em;}
.tp25{top:25em;}
.tp30{top:30em;}
.tp35{top:35em;}
.tp40{top:40em;}
.tp45{top:45em;}
.tp50{top:50em;}
.bt0{bottom:0em;}
.bt5{bottom:0em;}
.bt10{bottom:10em;}
.bt15{bottom:15em;}
.bt20{bottom:20em;}
.bt25{bottom:25em;}
.bt30{bottom:30em;}
.bt35{bottom:35em;}
.bt40{bottom:40em;}
.bt45{bottom:45em;}
.bt50{bottom:50em;}
.zi1{ z-index:1;}
.zi2{ z-index:2;}
.zi3{ z-index:3;}
.zi4{ z-index:4;}
.zi5{ z-index:5;}
/*}}}*/
/***
!Description
2010.01.21
<<<
*pplx added
<<<
!CSS
***/
/*{{{*/
/* CSS Document */
.rc {-moz-border-radius: 10px;  -webkit-border-radius: 10px;  border:1px solid #fff; }
.fr {border:1px solid #ccc; padding:0.25em;}

.byline {
font-family: "Lucida Grande", Tahoma;
	font-size: 0.865em;
	font-weight: lighter;
	font-variant: normal;
	text-transform: uppercase;
	color: #666666;
	letter-spacing: 0.4em;
	display: block;
	margin-bottom: 1.734em;
	padding:0em 0em 0em 1em;
	}
	
.and {font-family: Baskerville, "Goudy Old Style", "Palatino", "Book Antiqua", serif;
	font-style: italic;
	color: #777;
	}
 
 

.tc {text-align:center;}
.tr {text-align:right;}
.tl {text-align:left;}
.b{ font-weight:bold;}
.pl1{padding-left:1em;}
.pl2{padding-left:2em;}
.pl3{padding-left:3em;}

.ppl2{padding-left:1.8%;}
.ppl3{padding-left:3.13%;}
.ppl5{padding-left:4.8%;}


.water{color:#5582d1;}
.earth{color:#4e3e2c;}
.air{color:#f1fff7;}
.fire{ color:#ff8a19;}
 /* drinks food */
 .wine{color:#4a040a;}
 .beer{color:#F0C030;}
 .caffe{color:#473523;}
 .caffe-cream{color:#b68d3d;}
 .espresso{color:#2c1901;}
 .caramel{color:#ab671f;}
 .chocolate{color:#290200;}
 .black-pepper{color:#444334;}
 .pepper-lite{color:#8d8a72;}
 
 .lipstick{color:#c20c0c;}
 .oldbook{font-family:"Book Antiqua","Warnock Pro","Goudy Old Style","Palatino",Georgia,serif;}
.note{font-family:Georgia, "Times New Roman", Times, serif; font-style:italic; font-size:0.9em; margin:0.1em; color:#333;} 
.mono{font-family:"Courier New", Courier, monospace;}
/*}}}*/
/***
!Description

!CSS
***/
/*{{{*/
.main { 
width:70em;margin:0 auto;text-align:left;  }

.clear {clear:both;}

.dl1,
.dl2,
.dl5,
.dl10,
.dl15,
.dl20,
.dl25,
.dl30,
.dl35,
.dl40,
.dl45,
.dl50,
.dl55,
.dl60,
.dl65,
.dl70,
.dl75{float:left; display: inline; }

.dr1,
.dr2,
.dr5,
.dr10,
.dr15,
.dr20,
.dr25,
.dr30,
.dr35,
.dr40,
.dr45,
.dr50,
.dr55,
.dr60,
.dr65,
.dr70,
.dr75
{float:right; display: inline; }

.dl1, .dr1 {width:1em;}
.dl2, .dr2 {width:2em;}
.dl5, .dr5{width:5em;}
.dl10, .dr10{width:10em;}
.dl15, .dr15{width:15em;}
.dl20, .dr20{width:20em;}
.dl25, .dr25{width:25em;}
.dl30, .dr30{width:30em;}
.dl35, .dr35{width:35em;}
.dl40, .dr40{width:40em;}
.dl45, .dr45{width:45em;}
.dl50, .dr50{width:50em;}
.dl55, .dr55{width:55em;}
.dl60, .dr60{width:60em;}
.dl65, .dr65{width:65em;}
.dl70, .dr70{width:70em;}
.dl75, .dr75{width:75em;}


.ml5{margin-left:5em;}
.ml10{margin-left:10em;}
.ml15{margin-left:15em;}
.ml20{margin-left:20em;}
.ml25{margin-left:25em;}
.ml30{margin-left:30em;}
.ml35{margin-left:35em;}
.ml40{margin-left:40em;}
.ml45{margin-left:45em;}
.ml50{margin-left:50em;}
.ml55{margin-left:55em;}
.ml60{margin-left:60em;}
.ml65{margin-left:65em;}
.ml70{margin-left:70em;}
.ml75{margin-left:75em;}

.mr5{margin-right:5em;}
.mr10{margin-right:10em;}
.mr15{margin-right:15em;}
.mr20{margin-right:20em;}
.mr25{margin-right:25em;}
.mr30{margin-right:30em;}
.mr35{margin-right:35em;}
.mr40{margin-right:40em;}
.mr45{margin-right:45em;}
.mr50{margin-right:50em;}
.mr55{margin-right:55em;}
.mr60{margin-right:60em;}
.mr65{margin-right:65em;}
.mr70{margin-right:70em;}
.mr75{margin-right:75em;}

.mt1{margin-top:1em;}
.mt5{margin-top:5em;}
.mt10{margin-top:10em;}
.mt20{margin-top:20em;}
.mt30{margin-top:30em;}
.mt40{margin-top:40em;}
.mt50{margin-top:50em;}

.fluid {width:auto;    float:none;}

.hp{width:100%;  float:left; }

.clearfix, .main{ display:block;} 

.clearfix:after, .main:after {
     visibility: hidden;
     display: block;
     font-size: 0;
     content: " ";
     clear: both;
     height: 0;
	 
     }

/* IE5/MAC hack \*/
* html .clearfix{ display: inline;  height: 1px;}
/* close */ 
/*}}}*/
/***
!Description

!CSS
***/
/*{{{*/
body {text-align:center;}
ol {margin-left:2em;}
/*}}}*/
/*{{{*/
.dp5,
.dp10,
.dp15,
.dp20,
.dp25,
.dp30,
.dp33,
.dp35,
.dp40,
.dp45,
.dp50,
.dp55,
.dp60,
.dp65,
.dp67,
.dp70,
.dp75,
.dp80,
.dp85,
.dp90,
.dp95,
.dp100
{float:left; display: inline; }
	
.dp5{width:5%;}
.dp10{width:10%;*width:9.9%;}
.dp15{width:15%;*width:14.9%;}
.dp20{width:20%;*width:19.9%;}
.dp25{width:25%;*width:24.9%; }
.dp30{width:30%;*width:29.9%;}
.dp33{width:33.33%;*width:33.3%;}
.dp35{width:35%;*width:34.9%;}
.dp40{width:40%;*width:39.9%;}
.dp45{width:45%;*width:44.9%;}
.dp50{width:50%;*width:49.9%;}
.dp55{width:55%;*width:54.9%;}
.dp60{width:60%;*width:59.9%;}
.dp65{width:65%;*width:64.9%;}
.dp67{width:66.67%;*width:66.6%;}
.dp70{width:70%;*width:69.9%;}
.dp75{width:75%;*width:74.9%;}
.dp80{width:80%;*width:79.9%;}
.dp85{width:85%;*width:84.9%;}
.dp90{width:90%;*width:89.9%;}
.dp95{width:95%;*width:94.9%;}
.dp100{width:100%;*width:99.9%;}
/*}}}*/
/***
!Description

!CSS
***/
/*{{{*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, code,
del, dfn, em, img, q, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
}

body { 
  line-height: 1.5; 
}

/* Tables still need 'cellspacing="0"' in the markup. */
table { border-collapse: separate; border-spacing: 0; }
caption, th, td { text-align: left; font-weight: normal; }
table, td, th { vertical-align: middle; }

/* Remove possible quote marks (") from <q>, <blockquote>. */
blockquote:before, blockquote:after, q:before, q:after { content: ""; }
blockquote, q { quotes: "" ""; }

/* Remove annoying border on linked images. */
a img { border: none; }
/*}}}*/
/***
!Description

!CSS
***/
/*{{{*/
/* Just name all ID elements you will need in your site

Emastic suports DIV inside DIV with same width.

<div id="sideNav">
<div class="dl20"> Hello World! </div>
<div class="dl10"> Hello CSS! </div>
<div>
*/

/* 
#header, #sideNav, #footer {float:left; display:inline;}
*/
/*}}}*/
/***
Here are the changes, that have to be made, to overwrite the core predefinitions.
***/
/*{{{*/
/*-- new for clearing floats --*/
.outer{
	overflow: auto;
}

.tabContents {
	overflow: auto;
}

/* new for emastic */
.box {
	background: [[ColorPalette::Background]];
	border-right: 1px [[ColorPalette::TertiaryMid]] solid;
	border-bottom: 1px [[ColorPalette::TertiaryMid]] solid;

	padding: 1px 1em 0.75em;
	margin:  1em .5em 0.25em;
}

#sidebarOptions .input {
	margin: 0.4em 5%; 
}

.txtOptionInput, .pasOptionInput {
	width: 90%;
}
/*}}}*/
/***
|grid:|EmasticGrid|
|ie:|EmasticIe|
|reset:|EmasticReset|
|type:|EmasticType|
|absoluteGrid:|EmasticAbsolut|
|gadgets:|EmasticGadgets|
|percentGrid:|EmasticPercent|
|semantic:|EmasticSemantic|
|freeStyle:|EmFreeStyle|

|Author:|Vladimir Carrer http://www.vcarrer.com/|
|License:|MIT license - see: http://code.google.com/p/emastic/|
|Source:|http://code.google.com/p/emastic/|
|Version:|emastic grid system V0.8 (beta 3)|
|Contributor:|Mario Pietsch|

!Description
The EmasticSystem has been generated to work with the ~FreeStyle package.

!Important
There have been ''no changes'' made to the CSS code, except covering it inside ~TiddlyWiki markup.

***/

/***
Only some parts are active at the moment, since the core works against an external layout, at the moment. (Or I haven't found the right switches :)
***/
/*{{{*/
/*[[EmasticReset] ]*/
/*[[EmasticIe] ]*/
/*[[EmasticType] ]*/

[[EmasticGrid]]
[[EmasticAbsolut]]
[[EmasticPercent]]
[[EmasticGadgets]]
/*-- need this at the moment. may be better solution --*/
[[EmFreeStyle]]

/*}}}*/
/***
!Description

!CSS
***/
/*{{{*/

body { font:75%/1.5em Arial, Helvetica, sans-serif;
font-size-adjust:none;
font-style:normal;
font-variant:normal;
font-weight:normal;
 }

p { padding:0 0 1.5em 1em;color:#111; word-spacing:0.08em;   letter-spacing:0.03em; }
p img       { float: left; margin: 0 1em 1em 0; padding: 0; }
p img.right { float: right; margin: 0 0 1em 1em;  }

h1,h2{ font-weight:normal; color: #333; font-family:Georgia, "Times New Roman", serif; letter-spacing: 2px; word-spacing:0.1em;  }
h3,h4,h5,h6 { font-weight: normal; color: #333; font-family:Georgia, "Times New Roman", serif; }


h1 { font-size: 2.2em;  margin-bottom: 0.682em; }
h2 { font-size: 1.9em;  margin-bottom: 0.79em; }
h3 { font-size: 1.7em;  margin-bottom: 0.882em; }
h4 { font-size: 1.4em;  margin-bottom: 1.071em; }
h5,h6 { font-size: 1.3em;  margin-bottom: 1,154em; }


li ul, 
li ol  { margin:0 1.5em; }
ul, ol { margin: 0 1.5em 1.5em 1.5em; }


dl { margin: 0 0 1.5em 0; }
dl dt { font-weight: bold; }
dl dd { margin-left: 1.5em; }

a { color: #035292; text-decoration: none; }
a:hover { text-decoration: underline; }


table {  margin-bottom: 1.5em; border-collapse: collapse; }
th {font-weight: bold; }
tr, th, td { margin:0; padding:0 1.5em 0 1em; height:18px; }
tfoot { font-style: italic;  }
caption { text-align:center; font-family:Georgia, serif;  }


abbr, acronym { border-bottom: 1px dotted #000; }
address { margin-top: 1.5em; font-style: italic; }
del { color: #000; }


blockquote { padding-left:1.5em; margin: 1.5em; border-left:3px solid #ccc; font-style:italic;  }
strong { font-weight: bold; }
em, dfn { font-style: italic; }
dfn { font-weight: bold; }
pre, code { margin: 1.5em 0; white-space: pre; }
pre, code, tt { font: 1em monospace; line-height: 1.5; } 
tt { display: block; margin: 1.5em 0; }
hr {margin-bottom:1.5em;}
/*}}}*/
This is mainly a standard TW with some preparations to use the emastic[1] grid system. The theme generator is FreeStyle[2], to make the UI more flexible.
<br>
Learn more: 
[2] http://FreeStyle.tiddlyspot.com
[1] http://code.google.com/p/emastic
<br>
Select a new Theme<<selectTheme>>
Select a new Palette<<selectPalette>>

!!!!Additions:
>SelectThemePlugin
>EmasticSystem
>><<list filter [tag[EmasticSystem]]>>
>MaloStyleSheet
>Themes
>><<list filter [tag[systemTheme]]>>
>Palette
>><<list filter [tag[systemPalette]]>>
/***
|Name:|LessBackupsPlugin|
|Description:|Intelligently limit the number of backup files you create|
|Version:|3.0.1 ($Rev: 2320 $)|
|Date:|$Date: 2007-06-18 22:37:46 +1000 (Mon, 18 Jun 2007) $|
|Source:|http://mptw.tiddlyspot.com/#LessBackupsPlugin|
|Author:|Simon Baird|
|Email:|simon.baird@gmail.com|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Description
You end up with just backup one per year, per month, per weekday, per hour, minute, and second.  So total number won't exceed about 200 or so. Can be reduced by commenting out the seconds/minutes/hours line from modes array
!!Notes
Works in IE and Firefox only.  Algorithm by Daniel Baird. IE specific code by by Saq Imtiaz.
***/
//{{{

var MINS  = 60 * 1000;
var HOURS = 60 * MINS;
var DAYS  = 24 * HOURS;

if (!config.lessBackups) {
	config.lessBackups = {
		// comment out the ones you don't want or set config.lessBackups.modes in your 'tweaks' plugin
		modes: [
			["YYYY",  365*DAYS], // one per year for ever
			["MMM",   31*DAYS],  // one per month
			["ddd",   7*DAYS],   // one per weekday
			//["d0DD",  1*DAYS],   // one per day of month
			["h0hh",  24*HOURS], // one per hour
			["m0mm",  1*HOURS],  // one per minute
			//["s0ss",  1*MINS],   // one per second
			["latest",0]         // always keep last version. (leave this).
		]
	};
}

window.getSpecialBackupPath = function(backupPath) {

	var now = new Date();

	var modes = config.lessBackups.modes;

	for (var i=0;i<modes.length;i++) {

		// the filename we will try
		var specialBackupPath = backupPath.replace(/(\.)([0-9]+\.[0-9]+)(\.html)$/,
				'$1'+now.formatString(modes[i][0]).toLowerCase()+'$3')

		// open the file
		try {
			if (config.browser.isIE) {
				var fsobject = new ActiveXObject("Scripting.FileSystemObject")
				var fileExists  = fsobject.FileExists(specialBackupPath);
				if (fileExists) {
					var fileObject = fsobject.GetFile(specialBackupPath);
					var modDate = new Date(fileObject.DateLastModified).valueOf();
				}
			}
			else {
				netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
				var file = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
				file.initWithPath(specialBackupPath);
				var fileExists = file.exists();
				if (fileExists) {
					var modDate = file.lastModifiedTime;
				}
			}
		}
		catch(e) {
			// give up
			return backupPath;
		}

		// expiry is used to tell if it's an 'old' one. Eg, if the month is June and there is a
		// June file on disk that's more than an month old then it must be stale so overwrite
		// note that "latest" should be always written because the expiration period is zero (see above)
		var expiry = new Date(modDate + modes[i][1]);
		if (!fileExists || now > expiry)
			return specialBackupPath;
	}
}

// hijack the core function
window.getBackupPath_mptw_orig = window.getBackupPath;
window.getBackupPath = function(localPath) {
	return getSpecialBackupPath(getBackupPath_mptw_orig(localPath));
}

//}}}
/***
|''Name''|LineBreakHack|
|''Description''|formatter modifying TiddlyWiki's handling of line breaks, in front and after headings, lists and quots|
|''Author:''|Pietsch Mario|
|''Version''|0.3|
|''Status''|stable|
|''Source''|http://line-break-hack.tiddlyspace.com/#LineBreakHack|
|''Documentation''|http://line-break-hack-info.tiddlyspace.com/#LineBreakHackInfo|
|''License''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|

!!!Description
<<<
This formatter modifies the way line breaks in ~TiddlyWiki markup are rendered;
One linebreak in front of a heading will be removed.
2 linebreaks are replaced by: one {{{<br>}}}
<<<
!!!Revision History
<<<
!!!!V0.3 (2010-09-29)
*Two linebreaks now produce one empty line. 
**Have a look at {{{lineBreak.match}}}
<<<
***/
//{{{
(function(formatters) { //# set up alias

	// modify line-break formatter to find more than one \n
	var lineBreak = formatters[formatters.findByField("name", "lineBreak")];
//	lineBreak.match = "\\n+|<br ?/?>";
	lineBreak.match = "\\n{1,2}|<br ?/?>";


	//remove one line break before heading.
	var heading = formatters[formatters.findByField("name", "heading")];
		merge( heading, {termRegExp: /(\n+)/mg});

		heading.match = "^\n?!{1,6}";
		heading.handler = function(w) {
			if (w.matchText[0]=='\n') w.matchLength = w.matchLength - 1;
			w.subWikifyTerm(createTiddlyElement(w.output,"h" + w.matchLength), this.termRegExp);
		};
	
	for (var i=0; i<formatters.length; i++) {
		if (formatters[i].name == "list") {
			merge( formatters[i], {termRegExp: /(\n{1,2})/mg});
		}

		if (formatters[i].name == "quoteByBlock") {
			merge( formatters[i], {termRegExp: /(^<<<(\n{1,2}|$))/mg});
		}

		if (formatters[i].name == "quoteByLine") {
			merge( formatters[i], {termRegExp: /(\n{1,2})/mg});
			break;
		} // if ..
	} // for ..


})(config.formatters); //# end of alias
//}}}
!Description
This package contains NoCaseListPlugin, NumberedTextListPlugin and the Examples tagged ListPackage.

<<list filter [tag[ListPackage]]>>
/***
|''Name:''|LoadRemoteFileThroughProxy (previous LoadRemoteFileHijack)|
|''Description:''|When the TiddlyWiki file is located on the web (view over http) the content of [[SiteProxy]] tiddler is added in front of the file url. If [[SiteProxy]] does not exist "/proxy/" is added. |
|''Version:''|1.1.0|
|''Date:''|mar 17, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#LoadRemoteFileHijack|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
***/
//{{{
version.extensions.LoadRemoteFileThroughProxy = {
 major: 1, minor: 1, revision: 0, 
 date: new Date("mar 17, 2007"), 
 source: "http://tiddlywiki.bidix.info/#LoadRemoteFileThroughProxy"};

if (!window.bidix) window.bidix = {}; // bidix namespace
if (!bidix.core) bidix.core = {};

loadRemoteFile = function(url,callback,params)
{
 if ((document.location.toString().substr(0,4) == "http") && (url.substr(0,4) == "http")){ 
 url = store.getTiddlerText("SiteProxy", "/proxy/") + url;
 }
 return bidix.core.loadRemoteFile(url,callback,params);
}
bidix.core.loadRemoteFile = loadRemoteFile;
//}}}
/%
!info
|Name|LoadRemotePlugin|
|Source|http://www.TiddlyTools.com/#LoadRemotePlugin|
|Version|2.0.2|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|transclusion|
|Description|Load a plugin from a remote .js URL|
Usage
<<<
{{{
<<tiddler LoadRemotePlugin with: "label" "tip" "URL"
	"onloadfunction" "preloadedtest" "onrunfunction" "configoverlay">>
}}}
*''label'' and ''tip''<br>command link text and tooltip
*''URL''<br>location of .js (i.e., the remotely stored plugin file)
*''onloadfunction''<br>js code invoked after loading remote plugin (can be used to init values, display tiddlers, etc)
*''preloadedtest''<br>js expression evaluated to test if plugin has already been loaded
*''onrunfunction''<br>js code invoked //instead of onloadfunction// when plugin is already loaded
*''configoverlay''<br>name of tiddler containing js code with additional custom settings, tweaks, etc.
<<<
Examples
<<<
{{{
<<tiddler LoadRemotePlugin##show with:
	[[ImportTiddlersPlugin]]
	[[Load ImportTiddlersPlugin from svn.TiddlyWiki.org repository]]
	[[http://svn.tiddlywiki.org/Trunk/contributors/EricShulman/plugins/ImportTiddlersPlugin.js]]
	[[window.story.displayTiddler(null,'ImportTiddlers')]]
	[[version.extensions.ImportTiddlersPlugin!=undefined]]
	[[window.story.displayTiddler(null,'ImportTiddlers')]]
	[[ImportTiddlersPluginConfig]]
>>
}}}
<<tiddler LoadRemotePlugin##Examples>>
<<<
!end

!Examples
*[[TiddlyTools|http://www.TiddlyTools.com/]]
**{{block{<<tiddler LoadRemotePlugin##show with:
	[[ImportTiddlersPlugin]]
	[[Load ImportTiddlersPlugin from svn.TiddlyWiki.org repository]]
	[[http://svn.tiddlywiki.org/Trunk/contributors/EricShulman/plugins/ImportTiddlersPlugin.js]]
	[[window.story.displayTiddler(null,'ImportTiddlers')]]
	[[version.extensions.ImportTiddlersPlugin!=undefined]]
	[[window.story.displayTiddler(null,'ImportTiddlers')]]
	[[ImportTiddlersPluginConfig]]
>>}}}
**{{block{<<tiddler LoadRemotePlugin##show with:
	[[TiddlerTweakerPlugin]]
	[[Load TiddlerTweakerPlugin from svn.TiddlyWiki.org repository]]
	[[http://svn.tiddlywiki.org/Trunk/contributors/EricShulman/plugins/TiddlerTweakerPlugin.js]]
	[[window.story.displayTiddler(null,'TiddlerTweaker')]]
	[[version.extensions.TiddlerTweakerPlugin!=undefined]]
>>}}}
**{{block{<<tiddler LoadRemotePlugin##show with:
	[[RearrangeTiddlersPlugin]]
	[[Load RearrangeTiddlersPlugin from www.TiddlyTools.com]]
	[[http://www.TiddlyTools.com/plugins/RearrangeTiddlersPlugin.js]]
	[[window.story.forEachTiddler(function(t,e){window.story.refreshTiddler(t,null,true)}); window.refreshDisplay()]]
	[[Story.prototype.rearrangeTiddlersHijack_refreshTiddler!=undefined]]
>>}}}
*[[Abego Software|http://tiddlywiki.abego-software.de/]]
**{{block{<<tiddler LoadRemotePlugin##show with:
	[[YourSearchPlugin]]
	[[Load YourSearchPlugin from tiddlywiki.abego-software.de]]
	[[http://tiddlywiki.abego-software.de/archive/YourSearchPlugin/Plugin-YourSearch-src.2.1.1.js]]
	[[window.refreshPageTemplate()]]
	[[version.extensions.YourSearchPlugin!=undefined]]
>>}}}
*[[FirefoxPrivileges.TiddlySpot.com|http://firefoxprivileges.tiddlyspot.com/]]
**{{block{<<tiddler LoadRemotePlugin##show with:
	[[Firefox Privilege Manager]]
	[[Load Firefox Privilege Manager from svn.TiddlyWiki.org repository]]
	[[http://svn.tiddlywiki.org/Trunk/contributors/XavierVerges/plugins/FirefoxPrivilegesPlugin.js]]
	[[config.macros.firefoxPrivileges.onload()]]
	[[config.macros.firefoxPrivileges!=undefined]]
	[[backstage.switchTab('firefoxPrivileges')]]
>>}}}
*[[BillyReisinger.com:|http://www.billyreisinger.com/jash/]]
**{{block{<<tiddler LoadRemotePlugin##show with:
	[[Jash (JAvascript SHell)]]
	[[Load Jash (JAvascript SHell) from www.billyreisinger.com/jash]]
	[[http://www.billyreisinger.com/jash/source/latest/Jash.js]]
	[[window.jash.close()]]
	[[window.jash!=undefined]]
>>}}}
!end

!show
<html><nowiki><a href="javascript:;" title="$2"
onmouseover="
	this.href='javascript:void(eval(decodeURIComponent(%22(function(){try{('
	+encodeURIComponent(encodeURIComponent(this.onclick))
	+')()}catch(e){alert(e.description?e.description:e.toString())}})()%22)))';"
onclick="
	try { if ($5) {
		clearMessage();
		try {$6;} catch(e) {$4;}
		displayMessage('$1 is already installed.');
		return false;
	} } catch(e){;}
	var s=document.createElement('script');
	s.src='$3';
	s.onerror=function() {
		clearMessage();
		displayMessage('Could not load $1 from');
		displayMessage(this.src,this.src);
	};
	s.onload=function() { 
		clearMessage();
		{$4;}
		try { eval(store.getTiddlerText('$7','')); }
		catch(e) { displayMessage(e.description||e.toString()); }
		displayMessage('$1 has been loaded from');
		displayMessage(this.src,this.src);
	};
	s.onreadystatechange=function()  /* for IE */
		{ if(this.readyState=='complete') this.onload(); };
	document.getElementsByTagName('head')[0].appendChild(s);
	return false;
">$1</a></html>
!end
%/<<tiddler {{var src='LoadRemotePlugin';src+(tiddler&&tiddler.title==src?'##info':'##show');}}
	with: [[$1]] [[$2]] [[$3]] [[$4]] [[$5]] [[$6]] [[$7]]>>
<<tiddler LoadRemotePlugin##show with:
	[[ActivateStyling]]
	[[Load JQueryUI from pmario.tiddlyspace.com]]
	[[http://jqueryui.tiddlyspace.com/jQueryUI]]
	[[version.extensions.jqueryui=true]]
	[[version.extensions.jqueryui!=undefined]]
	[[window.story.displayTiddler(null,'StylingActivated')]]
>>
The MIT License

Copyright (c) 2010 Mario Pietsch

Permission 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:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE 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.
GettingStarted
FreeStyle
TiddlerMap
TiddlerMapTabsAZ
NumberedTextTest
[[Numbered vs xCase]]
TiddlerMapCol1
TiddlerMapTabs
StylingPackage
<hr>
XListPlugin
XCaseListPlugin
NumberedTextListPlugin
NoCaseListPlugin
LineBreakHack
<hr>
Theme: |@@<<selectTheme>>@@|
/*{{{*/
/*
	Malo - CSS Library
	Author:Vladimir Carrer
*/

/* CSS Reset */

/* not needed for TiddlyWiki 
html, body, div, p{
  margin: 0;
  padding: 0;
  border: 0;
  }
*/ 

/* CSS Grid */

/*
For center layout 
Define your default width in %, px or em

.main {  margin:0 auto; width:85%;}

*/

.dp20,
.dp25,
.dp33,
.dp50,
.dp100{float:left; display: inline; *margin-left:-0.04em; } /* IE margin hack */

/* dp = div percet */

.dp20{width:20%;}
.dp25{width:25%;}
.dp33{width:33.33%;}
.dp50{width:50%;}
.dp100{width:100%;}
.clear{ clear:both;}
/*}}}*/
Name: MpBlue
Background: #ffd
Foreground: #000
PrimaryPale: #ccd
PrimaryLight: #57c
PrimaryMid: #114
PrimaryDark: #012
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
Name: MpGreen
Background: #cec
Foreground: #000
PrimaryPale: #9b9
PrimaryLight: #385
PrimaryMid: #031
PrimaryDark: #020
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
Name: MptwBlue
Background: #fff
Foreground: #000
PrimaryPale: #cdf
PrimaryLight: #57c
PrimaryMid: #114
PrimaryDark: #012
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
Name: MptwGreen
Background: #fff
Foreground: #000
PrimaryPale: #9b9
PrimaryLight: #385
PrimaryMid: #031
PrimaryDark: #020
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
Name: MptwRed
Background: #fff
Foreground: #000
PrimaryPale: #eaa
PrimaryLight: #c55
PrimaryMid: #711
PrimaryDark: #500
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
Name: MptwSmoke
Background: #fff
Foreground: #000
PrimaryPale: #aaa
PrimaryLight: #777
PrimaryMid: #111
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
Name: MptwTeal
Background: #fff
Foreground: #000
PrimaryPale: #B5D1DF
PrimaryLight: #618FA9
PrimaryMid: #1a3844
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #f8f8f8
TertiaryLight: #bbb
TertiaryMid: #999
TertiaryDark: #888
Error: #f88
/***
|''Name''|NewTaggedCommand|
|''Description''|Creates a new tiddler, and tags it with it's parents title!|
|''Authors''|PMario|
|''Version''|0.1.0|
|''Date''|2011-07-02|
|''Status''|@@beta@@|
|''Source''|http://hoster.peermore.com/recipes/TeamWork/tiddlers.wiki#NewTaggedCommand|
|''License''|BSD|
|''CoreVersion''|2.5|
|''Keywords''|toolbar command add new tagged tiddler|
!!!Description
<<<
To use this new toolbar command you have to add {{{newTagged}}} to ToolbarCommands tiddler
eg:
{{{
|~ViewToolbar| +editTiddler newTagged ...
}}}
<<<
!!!Change the button text
<<<
If you want to change the buttons text from "newTagged" to eg "+", you need to create at tiddler [[zzConfig]] and tag it "systemConfig" and insert the following line.
//{{{
config.commands.newTagged.text = "+";
//}}}
<<<
!!!Code
***/
//{{{

config.commands.newTagged = {
	text: "newTagged",
	tooltip: "Create a new tiddler, with it's parent title!",

	isEnabled: function(tiddler) {
		return !readOnly;
	}
};

config.commands.newTagged.handler = function(event,src,title)
{
	var newTitle = config.macros.newTiddler.title;
	story.displayTiddler(null, newTitle);
	config.commands.editTiddler.handler.call(this,event,src,newTitle); 
	story.setTiddlerTag(newTitle, title, +1);
	return false;
};
//}}}
/***
|''Name:''|NoCaseListPlugin|
|''Description:''|Adds a new command ''noCase'' to the core list macro|
|''Author:''|Mario Pietsch|
|''Version:''|0.2.0|
|''Date:''|2010.07.28|
|''Status:''|''beta''|
|''Source:''|http://apm-plugins.tiddlyspot.com/#NoCaseListPlugin|
|''License''|[[MIT License]]|
|''CoreVersion:''|2.5.0|
|''Requires:''||
|''Documentation:''|this file|
|''Keywords:''|list, sort, not case sensitive, filter|

!Description
This plugin performs a alphabetical sort for tiddlers, but it is not case sensitive. That means ab = AB = aB = Ab! And it does some little filtering using the RegExp syntax. 
The RegExp Syntax can be a little bit tricky to read and configure. But the best description I have found is at [[regular-expressions.info]]. This plugin is aware of 'excludeLists', and does not display them.

!Example
{{{
<<list noCase title '[m]'>>
}}}
<<list noCase title '[m]'>>

!Default Format
{{{
<<list noCase>>
}}}

!Other Possibilities
<<<
!!!Reverse order
{{{
<<list noCase -title >>
}}}

!!!Some basic filtering
*Every tiddler title, that starts with a number from 0 to 9.
**Alphabetically sorted
{{{
<<list noCase -title '[0-9]'>>
}}}

*Every tiddler title, that starts with an ''"a"'' or ''"b"'' or ''"c"''.
{{{
<<list noCase title '[abc]'>>
}}}

*Every tiddler title, that starts with exactly ''abc''.
{{{
<<list noCase title 'abc'>>
}}}

I think this is enough power, for the beginning. See [[XCaseListPlugin|http://apm-plugins.tiddlyspot.com/#XCaseListPlugin]] for more.
<<<
!History
V 0.2.0 - 2010.07.28
*sorting can be done by custom field now

V 0.1.2 - 2010.03.04
*Fixed the source links

V 0.1.1 - 2010.02.24
*some minimum changes
*some more docu

V 0.1.0 - 2010.02.19
*Initial release

!Code
***/

/*{{{*/

if(!version.extensions.NoCaseListPlugin) { //# ensure that the plugin is only installed once
version.extensions.NoCaseListPlugin = { installed: true };

config.macros.list.noCase = {};
config.macros.list.noCase.handler = function(params)
{

var defaultField = "+title";
var lookupField  = "tags";
var lookupValue  = "excludeLists";
var lookupMatch  = false;
var results      = [];
var match        = null;

var sortField = params[1] || defaultField;

// get the sorting order
var asc = 1;
switch (sortField.substr(0, 1)) {
	case "-":
		asc = -1;
	case "+":
		sortField = sortField.substr(1);
		break;
	default:;
}

// define regExp and add ^ .. start of string
var regSnip = params[2] || '.'
var regExp = new RegExp('^' + regSnip, 'im'); 

store.forEachTiddler(
	function (title, tiddler) {
		var f = !lookupMatch;
		for (var lookup = 0; lookup < tiddler[lookupField].length; lookup++) {
			if (tiddler[lookupField][lookup] == lookupValue) {
				f = lookupMatch;
			}
		}
		if (f) {
			// check if tiddler sortField matches regExp
//			match = tiddler[sortField].match(regExp);
			match = tiddler.title.match(regExp);
			if (match) results.push(tiddler);
		} 
	}
);

// check, if sortField is a custom field
// sort and return the results.

//console.log('isStandard: ', TiddlyWiki.isStandardField(sortField), sortField, results);

if (TiddlyWiki.isStandardField(sortField)) {
	results.sort(function (a,b) {
		return a[sortField].toLowerCase() < b[sortField].toLowerCase() ? -asc : a[sortField].toLowerCase() == b[sortField].toLowerCase() ? 0 : asc;});
} 
else {
	results.sort(function (a, b) {
		return a.fields[sortField].toLowerCase() < b.fields[sortField].toLowerCase() ? - asc : a.fields[sortField].toLowerCase() == b.fields[sortField].toLowerCase() ? 0 : + asc;});
}
		
return results;
} // handler		

} //# end of "install only once"

/*}}}*/
{{{
{{dp50{<<list xCase title '[0-9]' "">>}}}                      {{dp50{<<list numberedText title '[. -]'>>}}}
}}}

{{dp50{<<list xCase title '[0-9]'>>}}}{{dp50{<<list numberedText +title '[. -]'>>}}}
/***
|''Name:''|NumberedTextListPlugin|
|''Description:''|Adds a new command ''numberedText'' to the core list macro|
|''Author:''|Mario Pietsch|
|''Version:''|0.2|
|''Date:''|2010.02.24|
|''Status:''|''beta''|
|''Source:''|http://apm-plugins.tiddlyspot.com|
|''License''|[[MIT License]]|
|''CoreVersion:''|2.5.0|
|''Requires:''|XCaseListPlugin|
|''Documentation:''|this file|
|''Keywords:''|list, sort, number, numbered list, filter|

!Description
*NumberedTextListPlugin requires  [[XCaseListPlugin|http://apm-plugins.tiddlyspot.com/#XCaseListPlugin]]!

*This plugin performs a numerical sort for tiddlers, that start with numbers in the title! It automatically performs a filter to the very first character of the tiddler title. It has to be a number!

For additional filtering it uses the {{{<<list filter [tag[]]>>}}} syntax.

!!!Example
{{{
<<list numberedText>> 
}}}
<<list numberedText title '[.]' 4 [tag[dot]]>>

!Default Format
{{{
<<list numberedText>>
}}}
!Full Format
<<<
{{{
<<list numberedText sortField delimiter numberOfSections tagList>>
}}}
!!!!!list numberedText
>Calls the core list macro, which gives its parameters to numberedText "sub" macro

!!!!!sortField
>The tiddler field, which is used for sorting
>''title'' or ''+title'' means ascending sort order
>''-title'' means descending sort order

!!!!!delimiter
>If you want to change this parameter you have to have the ''sortField'' definition. Otherwise it will not work!
>Is a regExp expression which defines the delimiter between 2 sections. 
>eg: 1.2.3 where 1 is section one, 2 = section two ....  

!!!!!numberOfSections
>Is the number of sections which are used for sorting. 
>If you have only 2 sections you can still use 4 sections for sorting, it doesn't change the result. But If you have 4 sections (eg: 1.2.a.b)  you need to change it to {{{<<list numberedText title '[.]' 2>>}}} than a.b are sorted alpahbetically!   

!!!!!tagList
>List of tags. eg: {{{"[tag[isTagged]]"}}}. It has to be covered inside qoutes!
>If MatchTagsPlugin is installed there are more possibilities. eg: {{{'[tag[thisTag AND thatTag]]'}}}
<<<

!More Possibilities
<<<

!!! Reverse order
{{{
<<list numberedText -title>>
}}}

!!! Different number delimiter
Number delimiters have to be enclosed in brackets '' '[ ]' '' and it has to be a string!
There should be _no_ spaces, except you want a "space" to be a delimiter!
{{{
<<list numberedText title '[-]'>>
}}}

!!! Two different number delimiters
{{{
<<list numberedText title '[.-]'>>
<<list numberedText title '[. ]'>>  .. dot and space !
}}}
*first:  1.1-3 tiddler, 1-1-2 tiddler, 
*second: 1.23 4 tiddler, 12 34.567 tiddler 

!!! 2 Sections 
Only 2 sections are used for sorting. 4 sections are default. More sections are also possible. (Didn't test that)
eg: 1''.''23''.''456''.''78
{{{
<<list numberedText title '[.]' 2>>
}}}

!!!Tag is needed, that tiddler is used
{{{
<<list numberedText title '[.]' 4 '[tag[MyTag]] [tag[OrTag]]'>>
}}}

!!!One number, no delimiters 
If you don't have any delimiters
eg: 11 tiddler, 2 tiddler, 3 tiddler use:
{{{
<<list numberedText title '[.]' 1>>
}}}
<<<

!Code
***/
/*{{{*/

if(!version.extensions.NumberedTextListPlugin) { //# ensure that the plugin is only installed once
version.extensions.NumberedTextListPlugin = { installed: true };

config.macros.list.numberedText = {};
config.macros.list.numberedText.handler = function(params) {

var defaultField  = '+title';
var lookupField = 'tags';
var lookupValue = 'excludeLists';
var lookupMatch = false;
var results = [];

var regDelim = params[2] || '[.]';	// default delimiter

var tagList = params[4] || '';		 

// default number of sections
var nbrSnips = (params[3]) ? parseInt(params[3]) : 4; 

var regStart = '(^\\d+)';	// first element has to be a digit
var regSnip  = '?(\\d+)?';	// other digits are optional
var regMod   = 'im';		// regExp modifier

var newReg = '';
for (var i=1; i<nbrSnips; i++) {
	newReg += regDelim + regSnip; 
};
newReg = regStart + newReg;

var regExp = new RegExp(newReg, regMod);
//var regExp = /(^\d+)[.:-]?(\d+)?[.:-]?(\d+)?[.:-]?(\d+)?/im;

var maxDigits = [];		// maximum digits in one section for zeroPad

for (var i=0; i<nbrSnips+1; i++) {maxDigits[i]=0;};

var match = null;

var sortField = params[1] || defaultField	// optional sort field
var pSortField = sortField;

var asc = 1;					// default sort order
switch (sortField.substr(0, 1)) {
	case "-":
		asc = -1;
		pSortField = '#' + pSortField;			//special prep for "list.expert"
		sortField = sortField.substr(1);
		break;
	case "+":
		pSortField = '#' + pSortField;			//special prep for "list.expert"
		sortField = sortField.substr(1);
		break;
	default: pSortField = '#+' + pSortField;	//special prep for "list.expert"
}

var newParams = ['numberedText', pSortField, '\\d', tagList];

results = config.macros.list['xCase'].handler(newParams);

for (var x = 0, xMax = results.length; x < xMax; x++) {
	match = results[x][sortField].match(regExp);
	for (var i = 0, max = match.length; i < max; i++) {
		if (match[i]) 
			maxDigits[i] = (maxDigits[i] < match[i].length) ? match[i].length : maxDigits[i];
	}; // for ..
}; 

results.sort(function (a,b) {
	var match = a[sortField].match(regExp);
	var aM = '';
	for (var i=1, max = match.length; i<max; i++) {
		aM += (match[i])? String.zeroPad(match[i], maxDigits[i]):'';
	}
	match = b[sortField].match(regExp);
	var bM = '';
	for (var i=1, max = match.length; i<max; i++) {
		bM += (match[i])? String.zeroPad(match[i], maxDigits[i]):'';
	}
	return aM < bM ? -asc : aM == bM ? 0 : asc;});	

return results;
};

} //# end of "install only once"

/*}}}*/

!Default Format
{{{
<<list numberedText>>
}}}
<<list numberedText title '[.]' 4 [tag[dot]]>>

!Sort order
{{{
<<list numberedText>>  <<list numberedText -title>>
}}}
{{dp50{<<list numberedText  title '[.]' 4 [tag[dot]]>>}}} {{dp50{<<list numberedText -title '[.]' 4 [tag[dot]]>>}}}


! Two / three different number delimiters
*first:  1.1-3 tiddler, 1-1-2 tiddler, 
*second: 1.23 4 tiddler, 12 34.567 tiddler 
{{{
<<list numberedText title '[.-]'>>   <<list numberedText title '[ .-]'>>  .. dot and space !
}}}
{{dp50{<<list numberedText title '[.-]' 4 '[tag[dot]] [tag[minus]]'>>}}}  {{dp50{<<list numberedText title '[ .-]' 4 '[tag[dot]] [tag[space]] [tag[minus]]'>>}}}


!!! Only 2 Sections 
Only 2 sections are used for sorting. 4 sections are default. More sections are also possible. (Didn't test that)
eg: 1''.''23''.''456''.''78
Only 2 sections are valid for sorting.
{{{
<<list numberedText title '[.]' 2>>
}}}
<<list numberedText title '[.]' 2 [tag[dot]]>>


! One number, no delimiters 
If you don't have any delimiters
eg: 11 tiddler, 2 tiddler, 3 tiddler use:
{{{
<<list numberedText title '[.]' 1>>
}}}
<<list numberedText title '[.]' 1 [tag[dot]]>>

/***
|''Name:''|PasswordOptionPlugin|
|''Description:''|Extends TiddlyWiki options with non encrypted password option.|
|''Version:''|1.0.2|
|''Date:''|Apr 19, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#PasswordOptionPlugin|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0 (Beta 5)|
***/
//{{{
version.extensions.PasswordOptionPlugin = {
	major: 1, minor: 0, revision: 2, 
	date: new Date("Apr 19, 2007"),
	source: 'http://tiddlywiki.bidix.info/#PasswordOptionPlugin',
	author: 'BidiX (BidiX (at) bidix (dot) info',
	license: '[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D]]',
	coreVersion: '2.2.0 (Beta 5)'
};

config.macros.option.passwordCheckboxLabel = "Save this password on this computer";
config.macros.option.passwordInputType = "password"; // password | text
setStylesheet(".pasOptionInput {width: 11em;}\n","passwordInputTypeStyle");

merge(config.macros.option.types, {
	'pas': {
		elementType: "input",
		valueField: "value",
		eventName: "onkeyup",
		className: "pasOptionInput",
		typeValue: config.macros.option.passwordInputType,
		create: function(place,type,opt,className,desc) {
			// password field
			config.macros.option.genericCreate(place,'pas',opt,className,desc);
			// checkbox linked with this password "save this password on this computer"
			config.macros.option.genericCreate(place,'chk','chk'+opt,className,desc);			
			// text savePasswordCheckboxLabel
			place.appendChild(document.createTextNode(config.macros.option.passwordCheckboxLabel));
		},
		onChange: config.macros.option.genericOnChange
	}
});

merge(config.optionHandlers['chk'], {
	get: function(name) {
		// is there an option linked with this chk ?
		var opt = name.substr(3);
		if (config.options[opt]) 
			saveOptionCookie(opt);
		return config.options[name] ? "true" : "false";
	}
});

merge(config.optionHandlers, {
	'pas': {
 		get: function(name) {
			if (config.options["chk"+name]) {
				return encodeCookie(config.options[name].toString());
			} else {
				return "";
			}
		},
		set: function(name,value) {config.options[name] = decodeCookie(value);}
	}
});

// need to reload options to load passwordOptions
loadOptionsCookie();

/*
if (!config.options['pasPassword'])
	config.options['pasPassword'] = '';

merge(config.optionsDesc,{
		pasPassword: "Test password"
	});
*/
//}}}
!NoCaseListPlugin
!!Needed
*TWTopListTheme
*EmasticSystem (maximum)
*NoCaseListPlugin
*EmasticStyleSheet

*MaloStyleSheet (minimum)
**You can replace EmasticSystem by Malo but you have to manually insert it into the StyleSheet chain, since it is not called by any style sheet.
**See the style sheet section in TWTopListTheme
/***
|Name:|SelectThemePlugin|
|Description:|Lets you easily switch theme and palette|
|Version:|1.0.1 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#SelectThemePlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!Notes
* Borrows largely from ThemeSwitcherPlugin by Martin Budden http://www.martinswiki.com/#ThemeSwitcherPlugin
* Theme is cookie based. But set a default by setting config.options.txtTheme in MptwConfigPlugin (for example)
* Palette is not cookie based. It actually overwrites your ColorPalette tiddler when you select a palette, so beware. 
!Usage
* {{{<<selectTheme>>}}} makes a dropdown selector
* {{{<<selectPalette>>}}} makes a dropdown selector
* {{{<<applyTheme>>}}} applies the current tiddler as a theme
* {{{<<applyPalette>>}}} applies the current tiddler as a palette
* {{{<<applyTheme TiddlerName>>}}} applies TiddlerName as a theme
* {{{<<applyPalette TiddlerName>>}}} applies TiddlerName as a palette
***/
//{{{

config.macros.selectTheme = {
	label: {
      		selectTheme:"select theme",
      		selectPalette:"select palette"
	},
	prompt: {
		selectTheme:"Select the current theme",
		selectPalette:"Select the current palette"
	},
	tags: {
		selectTheme:'systemTheme',
		selectPalette:'systemPalette'
	}
};

config.macros.selectTheme.handler = function(place,macroName)
{
	var btn = createTiddlyButton(place,this.label[macroName],this.prompt[macroName],this.onClick);
	// want to handle palettes and themes with same code. use mode attribute to distinguish
	btn.setAttribute('mode',macroName);
};

config.macros.selectTheme.onClick = function(ev)
{
	var e = ev ? ev : window.event;
	var popup = Popup.create(this);
	var mode = this.getAttribute('mode');
	var tiddlers = store.getTaggedTiddlers(config.macros.selectTheme.tags[mode]);
	// for default
	if (mode == "selectPalette") {
		var btn = createTiddlyButton(createTiddlyElement(popup,'li'),"(default)","default color palette",config.macros.selectTheme.onClickTheme);
		btn.setAttribute('theme',"(default)");
		btn.setAttribute('mode',mode);
	}
	for(var i=0; i<tiddlers.length; i++) {
		var t = tiddlers[i].title;
		var name = store.getTiddlerSlice(t,'Name');
		var desc = store.getTiddlerSlice(t,'Description');
		var btn = createTiddlyButton(createTiddlyElement(popup,'li'), name?name:t, desc?desc:config.macros.selectTheme.label['mode'], config.macros.selectTheme.onClickTheme);
		btn.setAttribute('theme',t);
		btn.setAttribute('mode',mode);
	}
	Popup.show();
	return stopEvent(e);
};

config.macros.selectTheme.onClickTheme = function(ev)
{
	var mode = this.getAttribute('mode');
	var theme = this.getAttribute('theme');
	if (mode == 'selectTheme')
		story.switchTheme(theme);
	else // selectPalette
		config.macros.selectTheme.updatePalette(theme);
	return false;
};

config.macros.selectTheme.updatePalette = function(title)
{
	if (title != "") {
		store.deleteTiddler("ColorPalette");
		if (title != "(default)")
			store.saveTiddler("ColorPalette","ColorPalette",store.getTiddlerText(title),
					config.options.txtUserName,undefined,"");
		refreshAll();
		if(config.options.chkAutoSave)
			saveChanges(true);
	}
};

config.macros.applyTheme = {
	label: "apply",
	prompt: "apply this theme or palette" // i'm lazy
};

config.macros.applyTheme.handler = function(place,macroName,params,wikifier,paramString,tiddler) {
	var useTiddler = params[0] ? params[0] : tiddler.title;
	var btn = createTiddlyButton(place,this.label,this.prompt,config.macros.selectTheme.onClickTheme);
	btn.setAttribute('theme',useTiddler);
	btn.setAttribute('mode',macroName=="applyTheme"?"selectTheme":"selectPalette"); // a bit untidy here
}

config.macros.selectPalette = config.macros.selectTheme;
config.macros.applyPalette = config.macros.applyTheme;

config.macros.refreshAll = { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
	createTiddlyButton(place,"refresh","refresh layout and styles",function() { refreshAll(); });
}};

//}}}
<<tabs txtMainTab "Timeline" "Timeline" TabTimeline "A-Z" "All tiddlers slider" TiddlerMapSlider "All" "All tiddlers" TabAll "Tags" "All tags" TabTags "More" "More lists" TabMore>>
/***
|''Name''|SimpleSearchPlugin|
|''Description''|displays search results as a simple list of matching tiddlers|
|''Authors''|FND|
|''Version''|0.4.1|
|''Status''|stable|
|''Source''|http://devpad.tiddlyspot.com/#SimpleSearchPlugin|
|''CodeRepository''|http://svn.tiddlywiki.org/Trunk/contributors/FND/plugins/SimpleSearchPlugin.js|
|''License''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|
|''Keywords''|search|
!Revision History
!!v0.2.0 (2008-08-18)
* initial release
!!v0.3.0 (2008-08-19)
* added Open All button (renders Classic Search option obsolete)
* sorting by relevance (title matches before content matches)
!!v0.4.0 (2008-08-26)
* added tag matching
!To Do
* tag matching optional
* animations for container creation and removal
* when clicking on search results, do not scroll to the respective tiddler (optional)
* use template for search results
!Code
***/
//{{{
if(!version.extensions.SimpleSearchPlugin) { //# ensure that the plugin is only installed once
version.extensions.SimpleSearchPlugin = { installed: true };

if(!config.extensions) { config.extensions = {}; }

config.extensions.SimpleSearchPlugin = {
	heading: "Search Results",
	containerId: "searchResults",
	btnCloseLabel: "close",
	btnCloseTooltip: "dismiss search results",
	btnCloseId: "search_close",
	btnOpenLabel: "Open all",
	btnOpenTooltip: "open all search results",
	btnOpenId: "search_open",

	displayResults: function(matches, query) {
		story.refreshAllTiddlers(true); // update highlighting within story tiddlers
		var el = document.getElementById(this.containerId);
		query = '"""' + query + '"""'; // prevent WikiLinks
		if(el) {
			removeChildren(el);
		} else { //# fallback: use displayArea as parent
			var container = document.getElementById("displayArea");
			el = document.createElement("div");
			el.id = this.containerId;
			el = container.insertBefore(el, container.firstChild);
		}
		var msg = "!" + this.heading + "\n";
		if(matches.length > 0) {
			msg += "''" + config.macros.search.successMsg.format([matches.length.toString(), query]) + ":''\n";
			this.results = [];
			for(var i = 0 ; i < matches.length; i++) {
				this.results.push(matches[i].title);
				msg += "* [[" + matches[i].title + "]]\n";
			}
		} else {
			msg += "''" + config.macros.search.failureMsg.format([query]) + "''"; // XXX: do not use bold here!?
		}
		createTiddlyButton(el, this.btnCloseLabel, this.btnCloseTooltip, config.extensions.SimpleSearchPlugin.closeResults, "button", this.btnCloseId);
		wikify(msg, el);
		if(matches.length > 0) { // XXX: redundant!?
			createTiddlyButton(el, this.btnOpenLabel, this.btnOpenTooltip, config.extensions.SimpleSearchPlugin.openAll, "button", this.btnOpenId);
		}
	},

	closeResults: function() {
		var el = document.getElementById(config.extensions.SimpleSearchPlugin.containerId);
		removeNode(el);
		config.extensions.SimpleSearchPlugin.results = null;
		highlightHack = null;
	},

	openAll: function(ev) {
		story.displayTiddlers(null, config.extensions.SimpleSearchPlugin.results);
		return false;
	}
};

config.shadowTiddlers.StyleSheetSimpleSearch = "/*{{{*/\n" +
	"#" + config.extensions.SimpleSearchPlugin.containerId + " {\n" +
	"\toverflow: auto;\n" +
	"\tpadding: 5px 1em 10px;\n" +
	"\tbackground-color: [[ColorPalette::TertiaryPale]];\n" +
	"}\n\n" +
	"#" + config.extensions.SimpleSearchPlugin.containerId + " h1 {\n" +
	"\tmargin-top: 0;\n" +
	"\tborder: none;\n" +
	"}\n\n" +
	"#" + config.extensions.SimpleSearchPlugin.containerId + " ul {\n" +
	"\tmargin: 0.5em;\n" +
	"\tpadding-left: 1.5em;\n" +
	"}\n\n" +
	"#" + config.extensions.SimpleSearchPlugin.containerId + " .button {\n" +
	"\tdisplay: block;\n" +
	"\tborder-color: [[ColorPalette::TertiaryDark]];\n" +
	"\tpadding: 5px;\n" +
	"\tbackground-color: [[ColorPalette::TertiaryLight]];\n" +
	"}\n\n" +
	"#" + config.extensions.SimpleSearchPlugin.containerId + " .button:hover {\n" +
	"\tborder-color: [[ColorPalette::SecondaryMid]];\n" +
	"\tbackground-color: [[ColorPalette::SecondaryLight]];\n" +
	"}\n\n" +
	"#" + config.extensions.SimpleSearchPlugin.btnCloseId + " {\n" +
	"\tfloat: right;\n" +
	"\tmargin: -5px -1em 5px 5px;\n" +
	"}\n\n" +
	"#" + config.extensions.SimpleSearchPlugin.btnOpenId + " {\n" +
	"\tfloat: left;\n" +
	"\tmargin-top: 5px;\n" +
	"}\n" +
	"/*}}}*/";
store.addNotification("StyleSheetSimpleSearch", refreshStyles);

// override Story.search()
Story.prototype.search = function(text, useCaseSensitive, useRegExp) {
	highlightHack = new RegExp(useRegExp ? text : text.escapeRegExp(), useCaseSensitive ? "mg" : "img");
	var matches = store.search(highlightHack, null, "excludeSearch");
	var q = useRegExp ? "/" : "'";
	config.extensions.SimpleSearchPlugin.displayResults(matches, q + text + q);
};

// override TiddlyWiki.search() to sort by relevance
TiddlyWiki.prototype.search = function(searchRegExp, sortField, excludeTag, match) {
	var candidates = this.reverseLookup("tags", excludeTag, !!match);
	var primary = [];
	var secondary = [];
	var tertiary = [];
	for(var t = 0; t < candidates.length; t++) {
		if(candidates[t].title.search(searchRegExp) != -1) {
			primary.push(candidates[t]);
		} else if(candidates[t].tags.join(" ").search(searchRegExp) != -1) {
			secondary.push(candidates[t]);
		} else if(candidates[t].text.search(searchRegExp) != -1) {
			tertiary.push(candidates[t]);
		}
	}
	var results = primary.concat(secondary).concat(tertiary);
	if(sortField) {
		results.sort(function(a, b) {
			return a[sortField] < b[sortField] ? -1 : (a[sortField] == b[sortField] ? 0 : +1);
		});
	}
	return results;
};

} //# end of "install only once"
//}}}
a reusable non-linear personal web notebook - based on a FreeStyle theme
apm Plugins
/%
!info
|Name|SortXList|
|Source||
|Version|0.2.0|
|Author|Mario Pietsch|
|Derived from:|http://www.tiddlytools.com/#ToggleLeftSidebar|
|License|http://creativecommons.org/licenses/by-nc-sa/3.0/at/|
|~CoreVersion|2.6|
|Type|transclusion|
|Description|Activate xList drag and drop sorting.|
Usage
<<<
{{{
<<tiddler SortXList>>
<<tiddler SortXList with: label tooltip>>
<<tiddler SortXList with: "&#x21d5" "Start xList sorter">>
}}}
Try to start xList sorter: <<tiddler SortXList##show
	with: "&#x21d5" "Start xList sorter">>
<<<
!end
!show
<<tiddler {{
	// some init here
'';}}>><html><nowiki><a href='javascript:;' title="$2"
onmouseover="
	this.href='javascript:void(eval(decodeURIComponent(%22(function(){try{('
	+encodeURIComponent(encodeURIComponent(this.onclick))
	+')()}catch(e){alert(e.description?e.description:e.toString())}})()%22)))';"
onclick="
	if (!version.extensions.jqueryui) {alert('Styling is not active!\nYou need to use: [ActivateStyling] macro.'); return false;}
	jQuery('.xList').sortable({
		axis: 'y',
		stop: function(event, ui) { 
			jQuery(ui.item).parent().attr('modified', 'true');
		},
	});	

	setStylesheet(
	'.ui-sortable li:after{content: \'\u202F \u21D5\'; cursor: n-resize; border: 1px dotted gray; color:green}' , 'XListStyles');
	return false;
">$1</a></html>
!end
%/<<tiddler {{
		var src='SortXList';
		src+(tiddler&&tiddler.title==src?'##info':'##show');
	}} with: "$1" "$2">>
/%
!info
|Name|SortXListCancel|
|Source||
|Version|0.2.0|
|Author|Mario Pietsch|
|Derived from:|http://www.tiddlytools.com/#ToggleLeftSidebar|
|License|http://creativecommons.org/licenses/by-nc-sa/3.0/at/|
|~CoreVersion|2.6|
|Type|transclusion|
|Description|Activate xList drag and drop sorting.|
Usage
<<<
{{{
<<tiddler SortXListCancel>>
<<tiddler SortXListCancel with: label tooltip>>
<<tiddler SortXListCancel with: "&#x2A2F" "Cancel xList sorter changes!">>
}}}
Try to start xList sorter: <<tiddler SortXListCancel##show
	with: "&#x2A2F" "Cancel xList sorter changes!">>
<<<
!end
!show
<<tiddler {{
	// some init here
'';}}>><html><nowiki><a href='javascript:;' title="$2"
onmouseover="
	this.href='javascript:void(eval(decodeURIComponent(%22(function(){try{('
	+encodeURIComponent(encodeURIComponent(this.onclick))
	+')()}catch(e){alert(e.description?e.description:e.toString())}})()%22)))';"
onclick="
	if (!version.extensions.jqueryui) {alert('Styling is not active!\nYou need to use: [ActivateStyling] macro.'); return false;}
	jQuery('.xList').sortable('destroy');
	story.forEachTiddler(function(t,e){story.refreshTiddler(t,null,true)});
	refreshDisplay();
	return false;
">$1</a></html>
!end
%/<<tiddler {{
		var src='SortXListCancel';
		src+(tiddler&&tiddler.title==src?'##info':'##show');
	}} with: "$1" "$2">>
/%
!info
|Name|SortXListSave|
|Source||
|Version|0.2.0|
|Author|Mario Pietsch|
|Derived from:|http://www.tiddlytools.com/#ToggleLeftSidebar|
|License|http://creativecommons.org/licenses/by-nc-sa/3.0/at/|
|~CoreVersion|2.6|
|Type|transclusion|
|Description|Activate xList drag and drop sorting.|
Usage
<<<
{{{
<<tiddler SortXListSave>>
<<tiddler SortXListSave with: label tooltip>>
<<tiddler SortXListSave with: "&#x2913" "Save modified lists.">>
}}}
Try to save modified lists: <<tiddler SortXListSave##show
	with: "&#x2913" "Save modified lists.">>
<<<
!end
!show
<<tiddler {{
	// some init here
'';}}>><html><nowiki><a href='javascript:;' title="$2"
onmouseover="
	this.href='javascript:void(eval(decodeURIComponent(%22(function(){try{('
	+encodeURIComponent(encodeURIComponent(this.onclick))
	+')()}catch(e){alert(e.description?e.description:e.toString())}})()%22)))';"
onclick="
	if (!version.extensions.jqueryui) {alert('Styling is not active!\nYou need to use: [ActivateStyling] macro.'); return false;}
	jQuery('.xList').each( function (idx) {
//		console.log('outside: ',jQuery(this) )

		if (jQuery(this).attr('modified') === 'true') {
//			console.log('inside: ',jQuery(this))
			var arr = jQuery(this).sortable( 'toArray');
//			console.log('arr: ', arr)
			var tag = jQuery(this).attr('tag');

			// check for ascending or descending sort order		
			var sortField = jQuery(this).attr('sortfield');
			var asc = 0;						// this method is different here, to sorting asc -asc !!
			switch (sortField.substr(0, 1)) {
				case '-':
					asc = -1;
				case '+':
					sortField = sortField.substr(1);
					break;
				default:	;
			}	

//		console.log('arr: ', arr);
			var t;
			var x = arr.length - 1;		// index starts at 0
			for (i=0; i<arr.length; i++) {
				if (store.tiddlerExists( arr[i])) {
					var field = {};

//					console.log('abs( asc*(x) + i): ', Math.abs( asc*(x) + i));

					field[sortField+tag] = String.zeroPad( Math.abs( asc*(x) + i) , 4);
					store.addTiddlerFields( arr[i], field)
				}
			} // for
		
			autoSaveChanges();

		} // if modified
	}) // each

	jQuery('.xList').sortable('destroy')


	return false;
">$1</a></html>
!end
%/<<tiddler {{
		var src='SortXListSave';
		src+(tiddler&&tiddler.title==src?'##info':'##show');
	}} with: "$1" "$2">>
|''Name:''|[[StandardTheme]]|
|''Description:''|Your description here!|
|''PageTemplate:''|PageTemplate|
|''ViewTemplate:''|ViewTemplate|
|''EditTemplate:''|EditTemplate|
|''StyleSheet:''|StyleSheet|
/*{{{*/
[[EmasticStyleSheet]]

.tiddlerMapSlider .button{
	display: inline-block;
	font-family: 'Courier New', courier, monospace;
	font-size: 110%;
}
/*}}}*/
/***
|''Name:''|StylingPackage|
|''Description:''|Styling package contains some tools to manipulate tag generated lists, to sort them with drag and drop|
|''Author:''|Mario Pietsch|
|''Date:''|2010.08.03|
|''Status:''|''beta''|
|''Source:''|http://apm-plugins.tiddlyspot.com/#StylingPackage|
|''License''|[[MIT License]]|
|''CoreVersion:''|2.5.0|
|''Keywords:''|drag drop list sorting extended lists|
|''UseCases''|http://apm-plugins.tiddlyspot.com/#XListPluginTest|
!!Installation
You only need to install 
*[[XListPlugin]]
*[[XCaseListPlugin]]
All the other elements can be draged to your browsers bookmarks bar. 
*LoadRemotejQueryUI
*SortXList
*SortXListSave
*SortXListCancel

!Bookmarks
Drag the following elements to your browsers toolbar: 
*Activate styling: <<tiddler LoadRemotejQueryUI>>
*Start sorting with: <<tiddler SortXList with: "&#x21d5" "Start xList sorter">>
*Save: <<tiddler SortXListSave with: "&#x21B5" "Save modified lists.">>
*Cancel <<tiddler SortXListCancel with: "&#x0078" "Cancel xList sorter changes!">>

{{{
!Bookmarks
Drag the following elements to your browsers toolbar: 
*Activate styling: <<tiddler LoadRemotejQueryUI>>
*Start sorting with: <<tiddler SortXList with: "&#x21d5" "Start xList sorter">>
*Save: <<tiddler SortXListSave with: "&#x21B5" "Save modified lists.">>
*Cancel <<tiddler SortXListCancel with: "&#x0078" "Cancel xList sorter changes!">>
}}}

!Play with it
*see: XListPluginTest

!Use case
I personally have exactly 2 use cases for that.
#[MainMenu] {{{<<xList xCase "sort." "." "[tag[mainMenu]]">>}}}
#[TopMenu] {{{<<xList xCase "sort." "." "[tag[topMenu]]">>}}}


!Other useful tools
*FieldsEditorPlugin 
**http://visualtw.ouvaton.org/VisualTW.html

!Known issues
*IE can't handle the LoadRemote UI.
*Refreshing the display doesn't allways work. 
*generates some hidden custom fields, which are not automatically removed, and will never be.
**''If you edit long lists and then decide to have a different tag. It will cause a lot of work!''
|''Name:''|[[TWDefaultTheme]]|
|''Description:''|Your description here!|
|''Generator:''|[[TW FreeStyle|http://FreeStyle.tiddlyspot.com]]|
|''Gen.Description:''|Automatically generated from: TWDefaultThemeProject|
|''PageTemplate:''|##PageTemplate|
|''ViewTemplate:''|##ViewTemplate|
|''EditTemplate:''|##EditTemplate|
|''StyleSheet:''|##StyleSheet|

!PageTemplate
<!--{{{-->


<!-- RowTwHeader -->
<div class='dp100'>

<!-- ColTwTitle -->
<div class='dp100'>

<!-- BoxTWHeader -->

<!-- defines the TW header. Comes from PageTemplate -->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
	<div class='headerShadow'>
		<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
		<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
	</div>
	<div class='headerForeground'>
		<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
		<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
	</div>
</div>
</div>
</div>	<!-- rows are allways 100% -->
<div class='clear'></div>	<!-- do not delete this! -->


<!-- RowTwBody -->
<div class='dp100'>

<!-- ColTWMainMenu -->
<div class='dp15'>

<!-- BoxTWMainMenu -->

<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
</div>


<!-- ColTWDisplayArea -->
<div id='displayArea' class='dp70'>

<!-- BoxTWMessageArea -->

<div id='messageArea'></div>


<!-- BoxTWTiddlerDisplay -->

<div id='tiddlerDisplay'></div>
</div>


<!-- ColTWSidebar -->
<div id='sidebar' class='dp15 dpfr' style='width:15%; position:relative;'>

<!-- BoxTWSidebarOptions -->

<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>


<!-- BoxTWSidebarTabs -->

<div id='sidebarTabs' refresh='content' force='true' tiddler='CSideBarTabs'></div>
</div>
</div>	<!-- rows are allways 100% -->
<div class='clear'></div>	<!-- do not delete this! -->

<!--}}}-->
!ViewTemplate
<!--{{{-->


<!-- TwViewTemplate -->
<div class='dp100'>

<!-- BoxVT_TwToolbar -->

<div class='toolbar' macro='toolbar [[ToolbarCommands::ViewToolbar]]'></div>


<!-- BoxVT_TwTitle -->

<div class='title' macro='view title'></div>


<!-- BoxVT_TwSubtitle -->

<div class='subtitle'>
	<span macro='view modifier link'></span>,<span macro='view modified date'></span> 
	(<span macro='message views.wikified.createdPrompt'></span> <span macro='view created date'></span>)</div>


<!-- BoxVT_TwTagged -->

<div class='tagged' macro='tags'></div>


<!-- BoxVT_TwTagging -->

<div class='tagging' macro='tagging'></div>


<!-- BoxVT_TWBody -->

<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
</div>

<!--}}}-->
!EditTemplate
<!--{{{-->


<!-- TwEditTemplate -->
<div class='dp100'>

<!-- BoxET_TwEditToolbar -->

<div class='toolbar' macro='toolbar [[ToolbarCommands::EditToolbar]]'></div>


<!-- BoxET_TwTitle -->

<div class='title' macro='view title'></div>


<!-- BoxET_TWEditTitle -->

<div class='editor' macro='edit title'></div>
<div macro='annotations'></div>


<!-- BoxET_TwEditBody -->

<div class='editor' macro='edit text'></div>


<!-- BoxET_TwTagging -->

<div class='editor' macro='edit tags'></div><div class='editorFooter'><span macro='message views.editor.tagPrompt'></span><span macro='tagChooser excludeLists'></span></div>
</div>

<!--}}}-->
!StyleSheet

/*{{{*/
/*-- new in emastic --*/

/* left main menu stuff */
#mainMenu {
	width:auto;		/*-- new in emastic --*/
	position:relative; 	/*-- new in emastic --*/
	text-align:right; 
	line-height:1.6em; 
	padding:1.5em 0.5em 0.5em 0.5em; 
	font-size:1.1em;
}

#sidebarTabs .tabContents{
	margin: 0  0.5em; /* new for emastic */
	width: auto;
}

#displayArea {
	float: left;		/*-- new for emastic --*/		
	padding: 0;		/*-- new for emastic --*/
	margin: 0;		/*-- new for emastic --*/
}

/***
This fixes a problem with the tabs slider
***/
#sidebarTabs .button {
	margin:0em 0.2em;
	padding:0.2em 0.3em;
	display:block;
}

/*--   emastic System --*/
[[EmasticSystem]]
[[EmFreeStyle]]

/*-- call the standard StyleSheet --*/
[[StyleSheet]]

/*}}}*/
|''Name:''|[[TWTopListTheme]]|
|''Description:''|Your description here!|
|''Generator:''|[[TW FreeStyle|http://FreeStyle.tiddlyspot.com]]|
|''Gen.Description:''|Automatically generated from: TWTopListTheme|
|''PageTemplate:''|##PageTemplate|
|''ViewTemplate:''|##ViewTemplate|
|''EditTemplate:''|##EditTemplate|
|''StyleSheet:''|##StyleSheet|

!PageTemplate
<!--{{{-->


<!-- RowTwHeader -->
<div class='dp100'>

<!-- ColTwTitle -->
<div class='dp100'>

<!-- BoxTWHeader -->

<!-- defines the TW header. Comes from PageTemplate -->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
	<div class='headerShadow'>
		<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
		<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
	</div>
	<div class='headerForeground'>
		<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
		<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
	</div>
</div>
</div>
</div>	<!-- rows are allways 100% -->
<div class='clear'></div>	<!-- do not delete this! -->


<!-- RowTWTopList -->
<div class='dp100'>

<!-- ColTWTopList -->
<div class='viewer dp100'>

<!-- BoxTWTopList -->

<div class='box outer' refresh='content' tiddler='TopListC'></div>
</div>
</div>	<!-- rows are allways 100% -->
<div class='clear'></div>	<!-- do not delete this! -->


<!-- RowTwBody -->
<div class='dp100'>

<!-- ColTWMainMenu -->
<div class='dp15'>

<!-- BoxTWMainMenu -->

<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
</div>


<!-- ColTWDisplayArea -->
<div id='displayArea' class='dp70'>

<!-- BoxTWMessageArea -->

<div id='messageArea'></div>


<!-- BoxTWTiddlerDisplay -->

<div id='tiddlerDisplay'></div>
</div>


<!-- ColTWSidebar -->
<div id='sidebar' class='dp15 dpfr' style='width:15%; position:relative;'>

<!-- BoxTWSidebarOptions -->

<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>


<!-- BoxTWSidebarTabs -->

<div id='sidebarTabs' refresh='content' force='true' tiddler='CSideBarTabs'></div>
</div>
</div>	<!-- rows are allways 100% -->
<div class='clear'></div>	<!-- do not delete this! -->

<!--}}}-->
!ViewTemplate
<!--{{{-->


<!-- TwViewTemplate -->
<div class='dp100'>

<!-- BoxVT_TwToolbar -->

<div class='toolbar' macro='toolbar [[ToolbarCommands::ViewToolbar]]'></div>


<!-- BoxVT_TwTitle -->

<div class='title' macro='view title'></div>


<!-- BoxVT_TwSubtitle -->

<div class='subtitle'>
	<span macro='view modifier link'></span>,<span macro='view modified date'></span> 
	(<span macro='message views.wikified.createdPrompt'></span> <span macro='view created date'></span>)</div>


<!-- BoxVT_TwTagged -->

<div class='tagged' macro='tags'></div>


<!-- BoxVT_TwTagging -->

<div class='tagging' macro='tagging'></div>


<!-- BoxVT_TWBody -->

<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
</div>

<!--}}}-->
!EditTemplate
<!--{{{-->


<!-- TwEditTemplate -->
<div class='dp100'>

<!-- BoxET_TwEditToolbar -->

<div class='toolbar' macro='toolbar [[ToolbarCommands::EditToolbar]]'></div>


<!-- BoxET_TwTitle -->

<div class='title' macro='view title'></div>


<!-- BoxET_TWEditTitle -->

<div class='editor' macro='edit title'></div>
<div macro='annotations'></div>


<!-- BoxET_TwEditBody -->

<div class='editor' macro='edit text'></div>


<!-- BoxET_TwTagging -->

<div class='editor' macro='edit tags'></div><div class='editorFooter'><span macro='message views.editor.tagPrompt'></span><span macro='tagChooser excludeLists'></span></div>
</div>

<!--}}}-->
!StyleSheet

/*{{{*/
/*-- new in emastic --*/

/* left main menu stuff */
#mainMenu {
	width:auto;		/*-- new in emastic --*/
	position:relative; 	/*-- new in emastic --*/
	text-align:right; 
	line-height:1.6em; 
	padding:1.5em 0.5em 0.5em 0.5em; 
	font-size:1.1em;
}

#sidebarTabs .tabContents{
	margin: 0  0.5em; /* new for emastic */
	width: auto;
}

#displayArea {
	float: left;		/*-- new for emastic --*/		
	padding: 0;		/*-- new for emastic --*/
	margin: 0;		/*-- new for emastic --*/
}

/***
This fixes a problem with the tabs slider
***/
#sidebarTabs .button {
	margin:0em 0.2em;
	padding:0.2em 0.3em;
	display:inline-block;
}

/*--   emastic System --*/
[[EmasticSystem]]
[[EmFreeStyle]]

/*-- call the standard StyleSheet --*/
[[StyleSheet]]

/*}}}*/
/***
|''Name''|TagOthersCommands|
|''Description''|''Tag'' and ''Untag'' every open tiddler with the name of the tiddler that activates the command.|
|''Authors''|PMario|
|''Version''|0.1.0|
|''Date''|2011-07-28|
|''Status''|@@beta@@|
|''Source''|http://hoster.peermore.com/recipes/TeamWork/tiddlers.wiki#TagWithStoryCommand|
|''License''|BSD|
|''CoreVersion''|2.5|
|''Keywords''|toolbar command story tag other open tiddler|
!!!Description
<<<
To use these new toolbar commands you have to add {{{tagOthers}}} and/or {{{untagOthers}}} to ToolbarCommands tiddler
eg:
{{{
|~ViewToolbar| +editTiddler ... > untagOthers tagOthers ... close ...
}}}
<<<
!!! Change the button text
<<<
If you want to change the buttons text from "tagOthers" to eg "something", you need to create at tiddler [[zzConfig]], tag it "systemConfig" and insert the following line.
//{{{
config.commands.tagOthers.text = "something";
config.commands.untagOthers.text = "somethingElse";
//}}}
<<<
!!! Disable the confirmation dialog
<<<
If you permanently want to get rid of the confirmation dialog, you need to create at tiddler [[zzConfig]], tag it "systemConfig" and handle {{{config.options.chkDisableTagOthersConfirm}}} there. 
@@Be warned! You can mess up your TW if you are not carefull with this option. But ''it speeds things up a lot :))''@@

<<option chkDisableTagOthersConfirm>> disable "tagOthers" confirmation dialog
<<option chkDisableUnTagOthersConfirm>> disable "''untagOthers''" confirmation dialog

<<option chkAutoSave>> auto save changes
<<<
!!! Auto enable confirmation dialog at reload
<<<
Disabling the confirmation dialog is stored with a cookie. If you want to activate the confirmation dialog at browser reaload, go to [[zzConfig]] and insert the following line.
{{{
config.options.chkDisableTagOthersConfirm = false;
config.options.chkDisableUnTagOthersConfirm = false;
}}}
<<<
!!!Code
***/
//{{{

config.commands.tagOthers = {
	text: "tagOthers",
	tooltip: "Tag all open tiddlers with this tiddlers name!",
	txtConfirm: "The following tiddlers will be tagged: [[%0]]",

	isEnabled: function(tiddler) {
		return (!readOnly && !( tiddler.title == 'systemConfig' ));
	},
};

config.commands.tagOthers.handler = function(event,src,title)
{
	var list = [], i, co = config.options; 

	// collect info about effected tiddlers.
	story.forEachTiddler(function(tt, tiddler){
		if (tt != title) list.push(tt);
	});

	
	if ( co.chkDisableTagOthersConfirm || confirm( this.txtConfirm.format([title]) + "\n\n" + list.join(', ')) ) {
		store.suspendNotifications;
		for ( i = 0; i < list.length; i++) {
			store.setTiddlerTag(list[i], 1, title);
		}
		store.resumeNotifications;
		store.notifyAll;
	}

	if (co.chkAutoSave) autoSaveChanges(true);
	return false;
};

config.commands.untagOthers = {
	text: "untagOthers",
	tooltip: "Remove this tiddler name tag, from other tiddlers!",
	txtConfirm: "Remove tag: [[%0]], from all open tiddlers:",

	isEnabled: function(tiddler) {
		return (!readOnly && !( tiddler.title == 'systemConfig' ));
	},
};

config.commands.untagOthers.handler = function(event,src,title)
{
	var list = [], i, co = config.options; 

	// collect info about effected tiddlers.
	story.forEachTiddler(function(tt, tiddler){
		if (tt != title) list.push(tt);
	});

	
	if ( co.chkDisableUnTagOthersConfirm || confirm( this.txtConfirm.format([title]) + "\n\n" + list.join(', ')) ) {
		store.suspendNotifications;
		for ( i = 0; i < list.length; i++) {
			store.setTiddlerTag(list[i], 0, title);
		}
		store.resumeNotifications;
		store.notifyAll;
	}

	if (co.chkAutoSave) autoSaveChanges(true);
	return false;
};
//}}}
/%
ABC:/%%/ <<tiddler TiddlerMap##Col with: A B C>>

/%
DEF:/%%/ <<tiddler TiddlerMap##Col with: D E F>>

/%
GHI:/%%/ <<tiddler TiddlerMap##Col with: G H I>>

/%
JKL:/%%/ <<tiddler TiddlerMap##Col with: J K L>>

/%
MNO:/%%/ <<tiddler TiddlerMap##Col with: M N O>>

/%
PQR:/%%/ <<tiddler TiddlerMap##Col with: P Q R>>

/%
STU:/%%/ <<tiddler TiddlerMap##Col with: S T U>>

/%
VW:/%%/ <<tiddler TiddlerMap##Col2 with: V W>>

/%
XYZ:/%%/ <<tiddler TiddlerMap##Col with: X Y Z>>

/%
0to9:/%%/ <<tiddler TiddlerMap##Col with: '0-3' '4-6' '7-9'>>

/%
!!!Col
{{dp33{''$1''<<list noCase title '[$1]'>>}}} {{dp33{''$2''<<list noCase title '[$2]'>>}}} {{dp33{''$3''<<list noCase title '[$3]'>>}}}
{{dp100{<br>}}}

!!!Col1
<hr>
@@$1@@
<<list noCase title '[$1]'>>
<hr>
!!!end

!!!Col2
{{dp50{''$1''<<list noCase title '[$1]'>>}}} {{dp50{''$2''<<list noCase title '[$2]'>>}}}
{{dp100{<br>}}}
!!!end

*Col3 
!!!Col3
{{dp33{''$1''<<list noCase title '[$1]'>>}}} {{dp33{''$2''<<list noCase title '[$2]'>>}}} {{dp33{''$3''<<list noCase title '[$3]'>>}}}
{{dp100{<br>}}}

!!!ColAZ3
{{dp33{''$1''-[$2]
<<list noCase title '$1[$2]'>>}}} {{dp33{''$1''-[$3]
<<list noCase title '$1[$3]'>>}}} {{dp33{''$1''-[$4]
<<list noCase title '$1[$4]'>>}}}
{{dp100{<br>}}}
!!!end

!!!ColAZ4
{{dp25{''$1''-[$2]
<<list noCase title '$1[$2]'>>}}} {{dp25{''$1''-[$3]
<<list noCase title '$1[$3]'>>}}} {{dp25{''$1''-[$4]
<<list noCase title '$1[$4]'>>}}} {{dp25{''$1''-[$5]
<<list noCase title '$1[$5]'>>}}}
{{dp100{<br>}}}
!!!end

!!!Col0to9
{{dp33{''$1''<<list noCase title '[$1]'>>}}} {{dp33{''$2''
<<list noCase title '[$2]'>>}}} {{dp33{''$3''
<<list noCase title '[$3]'>>}}}
{{dp100{<br>}}}
!!!end
%/
/%
A:/%%/ <<tiddler TiddlerMap##ColAZ3 with: A ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
B:/%%/ <<tiddler TiddlerMap##ColAZ3 with: B ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
C:/%%/ <<tiddler TiddlerMap##ColAZ3 with: C ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
D:/%%/ <<tiddler TiddlerMap##ColAZ3 with: D ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
E:/%%/ <<tiddler TiddlerMap##ColAZ3 with: E ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
F:/%%/ <<tiddler TiddlerMap##ColAZ3 with: F ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
G:/%%/ <<tiddler TiddlerMap##ColAZ3 with: G ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
H:/%%/ <<tiddler TiddlerMap##ColAZ3 with: H ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
I:/%%/ <<tiddler TiddlerMap##ColAZ3 with: I ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
J:/%%/ <<tiddler TiddlerMap##ColAZ3 with: J ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
K:/%%/ <<tiddler TiddlerMap##ColAZ3 with: K ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
L:/%%/ <<tiddler TiddlerMap##ColAZ3 with: L ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
M:/%%/ <<tiddler TiddlerMap##ColAZ3 with: M ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
N:/%%/ <<tiddler TiddlerMap##ColAZ3 with: N ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
O:/%%/ <<tiddler TiddlerMap##ColAZ3 with: O ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
P:/%%/ <<tiddler TiddlerMap##ColAZ3 with: P ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
Q:/%%/ <<tiddler TiddlerMap##ColAZ3 with: Q ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
R:/%%/ <<tiddler TiddlerMap##ColAZ3 with: R ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
S:/%%/ <<tiddler TiddlerMap##ColAZ3 with: S ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
T:/%%/ <<tiddler TiddlerMap##ColAZ3 with: T ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
U:/%%/ <<tiddler TiddlerMap##ColAZ3 with: U ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
V:/%%/ <<tiddler TiddlerMap##ColAZ3 with: V ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
W:/%%/ <<tiddler TiddlerMap##ColAZ3 with: W ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
X:/%%/ <<tiddler TiddlerMap##ColAZ3 with: X ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
Y:/%%/ <<tiddler TiddlerMap##ColAZ3 with: Y ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
Z:/%%/ <<tiddler TiddlerMap##ColAZ3 with: Z ABCDEFGHI JKLMNOPQR STUVWXYZ>>

/%
!Important
The following line calls a different definition

0to9:/%%/ <<tiddler TiddlerMap##Col0to9 with: '0-3' '4-6' '7-9'>>
/%
A:/%%/ <<tiddler TiddlerMap##ColAZ4 with: A ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
B:/%%/ <<tiddler TiddlerMap##ColAZ4 with: B ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
C:/%%/ <<tiddler TiddlerMap##ColAZ4 with: C ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
D:/%%/ <<tiddler TiddlerMap##ColAZ4 with: D ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
E:/%%/ <<tiddler TiddlerMap##ColAZ4 with: E ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
F:/%%/ <<tiddler TiddlerMap##ColAZ4 with: F ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
G:/%%/ <<tiddler TiddlerMap##ColAZ4 with: G ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
H:/%%/ <<tiddler TiddlerMap##ColAZ4 with: H ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
I:/%%/ <<tiddler TiddlerMap##ColAZ4 with: I ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
J:/%%/ <<tiddler TiddlerMap##ColAZ4 with: J ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
K:/%%/ <<tiddler TiddlerMap##ColAZ4 with: K ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
L:/%%/ <<tiddler TiddlerMap##ColAZ4 with: L ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
M:/%%/ <<tiddler TiddlerMap##ColAZ4 with: M ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
N:/%%/ <<tiddler TiddlerMap##ColAZ4 with: N ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
O:/%%/ <<tiddler TiddlerMap##ColAZ4 with: O ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
P:/%%/ <<tiddler TiddlerMap##ColAZ4 with: P ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
Q:/%%/ <<tiddler TiddlerMap##ColAZ4 with: Q ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
R:/%%/ <<tiddler TiddlerMap##ColAZ4 with: R ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
S:/%%/ <<tiddler TiddlerMap##ColAZ4 with: S ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
T:/%%/ <<tiddler TiddlerMap##ColAZ4 with: T ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
U:/%%/ <<tiddler TiddlerMap##ColAZ4 with: U ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
V:/%%/ <<tiddler TiddlerMap##ColAZ4 with: V ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
W:/%%/ <<tiddler TiddlerMap##ColAZ4 with: W ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
X:/%%/ <<tiddler TiddlerMap##ColAZ4 with: X ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
Y:/%%/ <<tiddler TiddlerMap##ColAZ4 with: Y ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
Z:/%%/ <<tiddler TiddlerMap##ColAZ4 with: Z ABCDEFG HIJKLMN OPQRSTU VWXYZ>>

/%
!Important
The following line calls a different definition

0to9:/%%/ <<tiddler TiddlerMap##Col0to9 with: '0-3' '4-6' '7-9'>>

/%
A:/%%/ <<tiddler TiddlerMap##Col1 with: A>>
/%
B:/%%/ <<tiddler TiddlerMap##Col1 with: B>>
/%
C:/%%/ <<tiddler TiddlerMap##Col1 with: C>>
/%
D:/%%/ <<tiddler TiddlerMap##Col1 with: D>>
/%
E:/%%/ <<tiddler TiddlerMap##Col1 with: E>>
/%
F:/%%/ <<tiddler TiddlerMap##Col1 with: F>>
/%
G:/%%/ <<tiddler TiddlerMap##Col1 with: G>>
/%
H:/%%/ <<tiddler TiddlerMap##Col1 with: H>>
/%
I:/%%/ <<tiddler TiddlerMap##Col1 with: I>>
/%
J:/%%/ <<tiddler TiddlerMap##Col1 with: J>>
/%
K:/%%/ <<tiddler TiddlerMap##Col1 with: K>>
/%
L:/%%/ <<tiddler TiddlerMap##Col1 with: L>>
/%
M:/%%/ <<tiddler TiddlerMap##Col1 with: M>>
/%
N:/%%/ <<tiddler TiddlerMap##Col1 with: N>>
/%
O:/%%/ <<tiddler TiddlerMap##Col1 with: O>>
/%
P:/%%/ <<tiddler TiddlerMap##Col1 with: P>>
/%
Q:/%%/ <<tiddler TiddlerMap##Col1 with: Q>>
/%
R:/%%/ <<tiddler TiddlerMap##Col1 with: R>>
/%
S:/%%/ <<tiddler TiddlerMap##Col1 with: S>>
/%
T:/%%/ <<tiddler TiddlerMap##Col1 with: T>>
/%
U:/%%/ <<tiddler TiddlerMap##Col1 with: U>>
/%
V:/%%/ <<tiddler TiddlerMap##Col1 with: V>>
/%
W:/%%/ <<tiddler TiddlerMap##Col1 with: W>>
/%
X:/%%/ <<tiddler TiddlerMap##Col1 with: X>>
/%
Y:/%%/ <<tiddler TiddlerMap##Col1 with: Y>>
/%
Z:/%%/ <<tiddler TiddlerMap##Col1 with: Z>>
/%
0:/%%/ <<tiddler TiddlerMap##Col1 with: 0>>
/%
1:/%%/ <<tiddler TiddlerMap##Col1 with: 1>>
/%
2:/%%/ <<tiddler TiddlerMap##Col1 with: 2>>
/%
3:/%%/ <<tiddler TiddlerMap##Col1 with: 3>>
/%
4:/%%/ <<tiddler TiddlerMap##Col1 with: 4>>
/%
5:/%%/ <<tiddler TiddlerMap##Col1 with: 5>>
/%
6:/%%/ <<tiddler TiddlerMap##Col1 with: 6>>
/%
7:/%%/ <<tiddler TiddlerMap##Col1 with: 7>>
/%
8:/%%/ <<tiddler TiddlerMap##Col1 with: 8>>
/%
9:/%%/ <<tiddler TiddlerMap##Col1 with: 9>>
{{tiddlerMapSlider{
<<slider chkA [[TiddlerMapCol1::A]] A 'display tiddler'>>/%
%/<<slider chkB [[TiddlerMapCol1::B]] B 'display tiddler'>>/%
%/<<slider chkC [[TiddlerMapCol1::C]] C 'display tiddler'>>/%
%/<<slider chkD [[TiddlerMapCol1::D]] D 'display tiddler'>>/%
%/<<slider chkE [[TiddlerMapCol1::E]] E 'display tiddler'>>/%
%/<<slider chkF [[TiddlerMapCol1::F]] F 'display tiddler'>>/%
%/<<slider chkG [[TiddlerMapCol1::G]] G 'display tiddler'>>/%
%/<<slider chkH [[TiddlerMapCol1::H]] H 'display tiddler'>>

<<slider chkI [[TiddlerMapCol1::I]] I 'display tiddler'>>/%
%/<<slider chkJ [[TiddlerMapCol1::J]] J 'display tiddler'>>/%
%/<<slider chkK [[TiddlerMapCol1::K]] K 'display tiddler'>>/%
%/<<slider chkL [[TiddlerMapCol1::L]] L 'display tiddler'>>/%
%/<<slider chkM [[TiddlerMapCol1::M]] M 'display tiddler'>>/%
%/<<slider chkN [[TiddlerMapCol1::N]] N 'display tiddler'>>/%
%/<<slider chkO [[TiddlerMapCol1::O]] O 'display tiddler'>>/%
%/<<slider chkP [[TiddlerMapCol1::P]] P 'display tiddler'>>

<<slider chkQ [[TiddlerMapCol1::Q]] Q 'display tiddler'>>/%
%/<<slider chkR [[TiddlerMapCol1::R]] R 'display tiddler'>>/%
%/<<slider chkS [[TiddlerMapCol1::S]] S 'display tiddler'>>/%
%/<<slider chkT [[TiddlerMapCol1::T]] T 'display tiddler'>>/%
%/<<slider chkU [[TiddlerMapCol1::U]] U 'display tiddler'>>/%
%/<<slider chkV [[TiddlerMapCol1::V]] V 'display tiddler'>>/%
%/<<slider chkW [[TiddlerMapCol1::W]] W 'display tiddler'>>/%
%/<<slider chkX [[TiddlerMapCol1::X]] X 'display tiddler'>>

<<slider chkY [[TiddlerMapCol1::Y]] Y 'display tiddler'>>/%
%/<<slider chkZ [[TiddlerMapCol1::Z]] Z 'display tiddler'>>

<<slider chk0 [[TiddlerMapCol1::0]] 0 'display tiddler'>>/%
%/<<slider chk1 [[TiddlerMapCol1::1]] 1 'display tiddler'>>/%
%/<<slider chk2 [[TiddlerMapCol1::2]] 2 'display tiddler'>>/%
%/<<slider chk3 [[TiddlerMapCol1::3]] 3 'display tiddler'>>/%
%/<<slider chk4 [[TiddlerMapCol1::4]] 4 'display tiddler'>>

<<slider chk5 [[TiddlerMapCol1::5]] 5 'display tiddler'>>/%
%/<<slider chk6 [[TiddlerMapCol1::6]] 6 'display tiddler'>>/%
%/<<slider chk7 [[TiddlerMapCol1::7]] 7 'display tiddler'>>/%
%/<<slider chk8 [[TiddlerMapCol1::8]] 8 'display tiddler'>>/%
%/<<slider chk9 [[TiddlerMapCol1::9]] 9 'display tiddler'>>}}}
<<tabs txtTiddlerMapTabs
ABC 'list "A/B/C" tiddlers' [[TiddlerMap::ABC]]
DEF 'list "D/E/F" tiddlers' [[TiddlerMap::DEF]]
GHI 'list "G/H/I" tiddlers' [[TiddlerMap::GHI]]
JKL 'list "J/K/L" tiddlers' [[TiddlerMap::JKL]]
MNO 'list "M/N/O" tiddlers' [[TiddlerMap::MNO]]
PQR 'list "P/Q/R" tiddlers' [[TiddlerMap::PQR]]
STU 'list "S/T/U" tiddlers' [[TiddlerMap::STU]]
VW  'list "V/W"   tiddlers' [[TiddlerMap::VW]]
XYZ 'list "X/Y/Z" tiddlers' [[TiddlerMap::XYZ]]
0-9 'list "0-9"   tiddlers' [[TiddlerMap::0to9]]
>>
<<tiddler TiddlerMapTabsInfo>>

<<tiddler [[TiddlerMapTabsAZ##Tabs]] with: 3>>
<<tiddler [[TiddlerMapTabsAZ##Tabs]] with: 4>>
/%
!Tabs
<<tabs txtTiddlerMapTabsAZ
A 'list "A" tiddlers' [[TiddlerMapAZ$1::A]]
B 'list "B" tiddlers' [[TiddlerMapAZ$1::B]]
C 'list "C" tiddlers' [[TiddlerMapAZ$1::C]]
D 'list "D" tiddlers' [[TiddlerMapAZ$1::D]]
E 'list "E" tiddlers' [[TiddlerMapAZ$1::E]]
F 'list "F" tiddlers' [[TiddlerMapAZ$1::F]]
G 'list "G" tiddlers' [[TiddlerMapAZ$1::G]]
H 'list "H" tiddlers' [[TiddlerMapAZ$1::H]]
I 'list "I" tiddlers' [[TiddlerMapAZ$1::I]]
J 'list "J" tiddlers' [[TiddlerMapAZ$1::J]]
K 'list "K" tiddlers' [[TiddlerMapAZ$1::K]]
L 'list "L" tiddlers' [[TiddlerMapAZ$1::L]]
M 'list "M" tiddlers' [[TiddlerMapAZ$1::M]]
N 'list "N" tiddlers' [[TiddlerMapAZ$1::N]]
O 'list "O" tiddlers' [[TiddlerMapAZ$1::O]]
P 'list "P" tiddlers' [[TiddlerMapAZ$1::P]]
Q 'list "Q" tiddlers' [[TiddlerMapAZ$1::Q]]
R 'list "R" tiddlers' [[TiddlerMapAZ$1::R]]
S 'list "S" tiddlers' [[TiddlerMapAZ$1::S]]
T 'list "T" tiddlers' [[TiddlerMapAZ$1::T]]
U 'list "U" tiddlers' [[TiddlerMapAZ$1::U]]
V 'list "V" tiddlers' [[TiddlerMapAZ$1::V]]
W 'list "W" tiddlers' [[TiddlerMapAZ$1::W]]
X 'list "X" tiddlers' [[TiddlerMapAZ$1::X]]
Y 'list "Y" tiddlers' [[TiddlerMapAZ$1::Y]]
Z 'list "Z" tiddlers' [[TiddlerMapAZ$1::Z]]
0-9 'list "0-9" tiddlers' [[TiddlerMapAZ$1::0to9]]
>>
!!!end
%/
!Description
This tiddler calls TiddlerMapAZ3 or TiddlerMapAZ4 which contains the column definition. 

!Usage
{{{
<<tiddler [[TiddlerMapTabsAZ##Tabs]] with: 3>>
or
<<tiddler [[TiddlerMapTabsAZ##Tabs]] with: 4>>
}}}
{{dpfr{[[TopListC]]}}}<<slider chkSliderTopListA TiddlerMapTabs "All tiddlers tabbed" "display all tiddlers tabbed">> <<slider chkSliderTopListB TiddlerMap "Tiddler Map" "display a map off all tiddlers">>
<<tiddler [[TiddlerMapTabsAZ##Tabs]] with: 4>>
/%
!Tabs
<<tabs txtTiddlerMapTabsAZ
A 'list "A" tiddlers' [[TiddlerMapAZ$1::A]]
B 'list "B" tiddlers' [[TiddlerMapAZ$1::B]]
C 'list "C" tiddlers' [[TiddlerMapAZ$1::C]]
D 'list "D" tiddlers' [[TiddlerMapAZ$1::D]]
E 'list "E" tiddlers' [[TiddlerMapAZ$1::E]]
F 'list "F" tiddlers' [[TiddlerMapAZ$1::F]]
G 'list "G" tiddlers' [[TiddlerMapAZ$1::G]]
H 'list "H" tiddlers' [[TiddlerMapAZ$1::H]]
I 'list "I" tiddlers' [[TiddlerMapAZ$1::I]]
J 'list "J" tiddlers' [[TiddlerMapAZ$1::J]]
K 'list "K" tiddlers' [[TiddlerMapAZ$1::K]]
L 'list "L" tiddlers' [[TiddlerMapAZ$1::L]]
M 'list "M" tiddlers' [[TiddlerMapAZ$1::M]]
N 'list "N" tiddlers' [[TiddlerMapAZ$1::N]]
O 'list "O" tiddlers' [[TiddlerMapAZ$1::O]]
P 'list "P" tiddlers' [[TiddlerMapAZ$1::P]]
Q 'list "Q" tiddlers' [[TiddlerMapAZ$1::Q]]
R 'list "R" tiddlers' [[TiddlerMapAZ$1::R]]
S 'list "S" tiddlers' [[TiddlerMapAZ$1::S]]
T 'list "T" tiddlers' [[TiddlerMapAZ$1::T]]
U 'list "U" tiddlers' [[TiddlerMapAZ$1::U]]
V 'list "V" tiddlers' [[TiddlerMapAZ$1::V]]
W 'list "W" tiddlers' [[TiddlerMapAZ$1::W]]
X 'list "X" tiddlers' [[TiddlerMapAZ$1::X]]
Y 'list "Y" tiddlers' [[TiddlerMapAZ$1::Y]]
Z 'list "Z" tiddlers' [[TiddlerMapAZ$1::Z]]
0-9 'list "0-9" tiddlers' [[TiddlerMapAZ$1::0to9]]
>>
!!!end
%/
/***
Description: Contains the stuff you need to use Tiddlyspot
Note, you also need UploadPlugin, PasswordOptionPlugin and LoadRemoteFileThroughProxy
from http://tiddlywiki.bidix.info for a complete working Tiddlyspot site.
***/
//{{{

// edit this if you are migrating sites or retrofitting an existing TW
config.tiddlyspotSiteId = 'apm-plugins';

// make it so you can by default see edit controls via http
config.options.chkHttpReadOnly = false;
window.readOnly = false; // make sure of it (for tw 2.2)
window.showBackstage = true; // show backstage too

// disable autosave in d3
if (window.location.protocol != "file:")
	config.options.chkGTDLazyAutoSave = false;

// tweak shadow tiddlers to add upload button, password entry box etc
with (config.shadowTiddlers) {
	SiteUrl = 'http://'+config.tiddlyspotSiteId+'.tiddlyspot.com';
	SideBarOptions = SideBarOptions.replace(/(<<saveChanges>>)/,"$1<<tiddler TspotSidebar>>");
	OptionsPanel = OptionsPanel.replace(/^/,"<<tiddler TspotOptions>>");
	DefaultTiddlers = DefaultTiddlers.replace(/^/,"[[WelcomeToTiddlyspot]] ");
	MainMenu = MainMenu.replace(/^/,"[[WelcomeToTiddlyspot]] ");
}

// create some shadow tiddler content
merge(config.shadowTiddlers,{

'TspotOptions':[
 "tiddlyspot password:",
 "<<option pasUploadPassword>>",
 ""
].join("\n"),

'TspotControls':[
 "| tiddlyspot password:|<<option pasUploadPassword>>|",
 "| site management:|<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . .  " + config.tiddlyspotSiteId + ">>//(requires tiddlyspot password)//<br>[[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]], [[download (go offline)|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download]]|",
 "| links:|[[tiddlyspot.com|http://tiddlyspot.com/]], [[FAQs|http://faq.tiddlyspot.com/]], [[blog|http://tiddlyspot.blogspot.com/]], email [[support|mailto:support@tiddlyspot.com]] & [[feedback|mailto:feedback@tiddlyspot.com]], [[donate|http://tiddlyspot.com/?page=donate]]|"
].join("\n"),

'WelcomeToTiddlyspot':[
 "This document is a ~TiddlyWiki from tiddlyspot.com.  A ~TiddlyWiki is an electronic notebook that is great for managing todo lists, personal information, and all sorts of things.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //What now?// &nbsp;&nbsp;@@ Before you can save any changes, you need to enter your password in the form below.  Then configure privacy and other site settings at your [[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]] (your control panel username is //" + config.tiddlyspotSiteId + "//).",
 "<<tiddler TspotControls>>",
 "See also GettingStarted.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Working online// &nbsp;&nbsp;@@ You can edit this ~TiddlyWiki right now, and save your changes using the \"save to web\" button in the column on the right.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Working offline// &nbsp;&nbsp;@@ A fully functioning copy of this ~TiddlyWiki can be saved onto your hard drive or USB stick.  You can make changes and save them locally without being connected to the Internet.  When you're ready to sync up again, just click \"upload\" and your ~TiddlyWiki will be saved back to tiddlyspot.com.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Help!// &nbsp;&nbsp;@@ Find out more about ~TiddlyWiki at [[TiddlyWiki.com|http://tiddlywiki.com]].  Also visit [[TiddlyWiki.org|http://tiddlywiki.org]] for documentation on learning and using ~TiddlyWiki. New users are especially welcome on the [[TiddlyWiki mailing list|http://groups.google.com/group/TiddlyWiki]], which is an excellent place to ask questions and get help.  If you have a tiddlyspot related problem email [[tiddlyspot support|mailto:support@tiddlyspot.com]].",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Enjoy :)// &nbsp;&nbsp;@@ We hope you like using your tiddlyspot.com site.  Please email [[feedback@tiddlyspot.com|mailto:feedback@tiddlyspot.com]] with any comments or suggestions."
].join("\n"),

'TspotSidebar':[
 "<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . .  " + config.tiddlyspotSiteId + ">><html><a href='http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download' class='button'>download</a></html>"
].join("\n")

});
//}}}
| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |
| 10/03/2013 21:16:49 | PMario | [[/|http://apm-plugins.tiddlyspot.com/]] | [[store.cgi|http://apm-plugins.tiddlyspot.com/store.cgi]] | . | [[index.html | http://apm-plugins.tiddlyspot.com/index.html]] | . |
/***
|''Name:''|UploadPlugin|
|''Description:''|Save to web a TiddlyWiki|
|''Version:''|4.1.3|
|''Date:''|Feb 24, 2008|
|''Source:''|http://tiddlywiki.bidix.info/#UploadPlugin|
|''Documentation:''|http://tiddlywiki.bidix.info/#UploadPluginDoc|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
|''Requires:''|PasswordOptionPlugin|
***/
//{{{
version.extensions.UploadPlugin = {
	major: 4, minor: 1, revision: 3,
	date: new Date("Feb 24, 2008"),
	source: 'http://tiddlywiki.bidix.info/#UploadPlugin',
	author: 'BidiX (BidiX (at) bidix (dot) info',
	coreVersion: '2.2.0'
};

//
// Environment
//

if (!window.bidix) window.bidix = {}; // bidix namespace
bidix.debugMode = false;	// true to activate both in Plugin and UploadService
	
//
// Upload Macro
//

config.macros.upload = {
// default values
	defaultBackupDir: '',	//no backup
	defaultStoreScript: "store.php",
	defaultToFilename: "index.html",
	defaultUploadDir: ".",
	authenticateUser: true	// UploadService Authenticate User
};
	
config.macros.upload.label = {
	promptOption: "Save and Upload this TiddlyWiki with UploadOptions",
	promptParamMacro: "Save and Upload this TiddlyWiki in %0",
	saveLabel: "save to web", 
	saveToDisk: "save to disk",
	uploadLabel: "upload"	
};

config.macros.upload.messages = {
	noStoreUrl: "No store URL in parmeters or options",
	usernameOrPasswordMissing: "Username or password missing"
};

config.macros.upload.handler = function(place,macroName,params) {
	if (readOnly)
		return;
	var label;
	if (document.location.toString().substr(0,4) == "http") 
		label = this.label.saveLabel;
	else
		label = this.label.uploadLabel;
	var prompt;
	if (params[0]) {
		prompt = this.label.promptParamMacro.toString().format([this.destFile(params[0], 
			(params[1] ? params[1]:bidix.basename(window.location.toString())), params[3])]);
	} else {
		prompt = this.label.promptOption;
	}
	createTiddlyButton(place, label, prompt, function() {config.macros.upload.action(params);}, null, null, this.accessKey);
};

config.macros.upload.action = function(params)
{
		// for missing macro parameter set value from options
		if (!params) params = {};
		var storeUrl = params[0] ? params[0] : config.options.txtUploadStoreUrl;
		var toFilename = params[1] ? params[1] : config.options.txtUploadFilename;
		var backupDir = params[2] ? params[2] : config.options.txtUploadBackupDir;
		var uploadDir = params[3] ? params[3] : config.options.txtUploadDir;
		var username = params[4] ? params[4] : config.options.txtUploadUserName;
		var password = config.options.pasUploadPassword; // for security reason no password as macro parameter	
		// for still missing parameter set default value
		if ((!storeUrl) && (document.location.toString().substr(0,4) == "http")) 
			storeUrl = bidix.dirname(document.location.toString())+'/'+config.macros.upload.defaultStoreScript;
		if (storeUrl.substr(0,4) != "http")
			storeUrl = bidix.dirname(document.location.toString()) +'/'+ storeUrl;
		if (!toFilename)
			toFilename = bidix.basename(window.location.toString());
		if (!toFilename)
			toFilename = config.macros.upload.defaultToFilename;
		if (!uploadDir)
			uploadDir = config.macros.upload.defaultUploadDir;
		if (!backupDir)
			backupDir = config.macros.upload.defaultBackupDir;
		// report error if still missing
		if (!storeUrl) {
			alert(config.macros.upload.messages.noStoreUrl);
			clearMessage();
			return false;
		}
		if (config.macros.upload.authenticateUser && (!username || !password)) {
			alert(config.macros.upload.messages.usernameOrPasswordMissing);
			clearMessage();
			return false;
		}
		bidix.upload.uploadChanges(false,null,storeUrl, toFilename, uploadDir, backupDir, username, password); 
		return false; 
};

config.macros.upload.destFile = function(storeUrl, toFilename, uploadDir) 
{
	if (!storeUrl)
		return null;
		var dest = bidix.dirname(storeUrl);
		if (uploadDir && uploadDir != '.')
			dest = dest + '/' + uploadDir;
		dest = dest + '/' + toFilename;
	return dest;
};

//
// uploadOptions Macro
//

config.macros.uploadOptions = {
	handler: function(place,macroName,params) {
		var wizard = new Wizard();
		wizard.createWizard(place,this.wizardTitle);
		wizard.addStep(this.step1Title,this.step1Html);
		var markList = wizard.getElement("markList");
		var listWrapper = document.createElement("div");
		markList.parentNode.insertBefore(listWrapper,markList);
		wizard.setValue("listWrapper",listWrapper);
		this.refreshOptions(listWrapper,false);
		var uploadCaption;
		if (document.location.toString().substr(0,4) == "http") 
			uploadCaption = config.macros.upload.label.saveLabel;
		else
			uploadCaption = config.macros.upload.label.uploadLabel;
		
		wizard.setButtons([
				{caption: uploadCaption, tooltip: config.macros.upload.label.promptOption, 
					onClick: config.macros.upload.action},
				{caption: this.cancelButton, tooltip: this.cancelButtonPrompt, onClick: this.onCancel}
				
			]);
	},
	options: [
		"txtUploadUserName",
		"pasUploadPassword",
		"txtUploadStoreUrl",
		"txtUploadDir",
		"txtUploadFilename",
		"txtUploadBackupDir",
		"chkUploadLog",
		"txtUploadLogMaxLine"		
	],
	refreshOptions: function(listWrapper) {
		var opts = [];
		for(i=0; i<this.options.length; i++) {
			var opt = {};
			opts.push();
			opt.option = "";
			n = this.options[i];
			opt.name = n;
			opt.lowlight = !config.optionsDesc[n];
			opt.description = opt.lowlight ? this.unknownDescription : config.optionsDesc[n];
			opts.push(opt);
		}
		var listview = ListView.create(listWrapper,opts,this.listViewTemplate);
		for(n=0; n<opts.length; n++) {
			var type = opts[n].name.substr(0,3);
			var h = config.macros.option.types[type];
			if (h && h.create) {
				h.create(opts[n].colElements['option'],type,opts[n].name,opts[n].name,"no");
			}
		}
		
	},
	onCancel: function(e)
	{
		backstage.switchTab(null);
		return false;
	},
	
	wizardTitle: "Upload with options",
	step1Title: "These options are saved in cookies in your browser",
	step1Html: "<input type='hidden' name='markList'></input><br>",
	cancelButton: "Cancel",
	cancelButtonPrompt: "Cancel prompt",
	listViewTemplate: {
		columns: [
			{name: 'Description', field: 'description', title: "Description", type: 'WikiText'},
			{name: 'Option', field: 'option', title: "Option", type: 'String'},
			{name: 'Name', field: 'name', title: "Name", type: 'String'}
			],
		rowClasses: [
			{className: 'lowlight', field: 'lowlight'} 
			]}
};

//
// upload functions
//

if (!bidix.upload) bidix.upload = {};

if (!bidix.upload.messages) bidix.upload.messages = {
	//from saving
	invalidFileError: "The original file '%0' does not appear to be a valid TiddlyWiki",
	backupSaved: "Backup saved",
	backupFailed: "Failed to upload backup file",
	rssSaved: "RSS feed uploaded",
	rssFailed: "Failed to upload RSS feed file",
	emptySaved: "Empty template uploaded",
	emptyFailed: "Failed to upload empty template file",
	mainSaved: "Main TiddlyWiki file uploaded",
	mainFailed: "Failed to upload main TiddlyWiki file. Your changes have not been saved",
	//specific upload
	loadOriginalHttpPostError: "Can't get original file",
	aboutToSaveOnHttpPost: 'About to upload on %0 ...',
	storePhpNotFound: "The store script '%0' was not found."
};

bidix.upload.uploadChanges = function(onlyIfDirty,tiddlers,storeUrl,toFilename,uploadDir,backupDir,username,password)
{
	var callback = function(status,uploadParams,original,url,xhr) {
		if (!status) {
			displayMessage(bidix.upload.messages.loadOriginalHttpPostError);
			return;
		}
		if (bidix.debugMode) 
			alert(original.substr(0,500)+"\n...");
		// Locate the storeArea div's 
		var posDiv = locateStoreArea(original);
		if((posDiv[0] == -1) || (posDiv[1] == -1)) {
			alert(config.messages.invalidFileError.format([localPath]));
			return;
		}
		bidix.upload.uploadRss(uploadParams,original,posDiv);
	};
	
	if(onlyIfDirty && !store.isDirty())
		return;
	clearMessage();
	// save on localdisk ?
	if (document.location.toString().substr(0,4) == "file") {
		var path = document.location.toString();
		var localPath = getLocalPath(path);
		saveChanges();
	}
	// get original
	var uploadParams = new Array(storeUrl,toFilename,uploadDir,backupDir,username,password);
	var originalPath = document.location.toString();
	// If url is a directory : add index.html
	if (originalPath.charAt(originalPath.length-1) == "/")
		originalPath = originalPath + "index.html";
	var dest = config.macros.upload.destFile(storeUrl,toFilename,uploadDir);
	var log = new bidix.UploadLog();
	log.startUpload(storeUrl, dest, uploadDir,  backupDir);
	displayMessage(bidix.upload.messages.aboutToSaveOnHttpPost.format([dest]));
	if (bidix.debugMode) 
		alert("about to execute Http - GET on "+originalPath);
	var r = doHttp("GET",originalPath,null,null,username,password,callback,uploadParams,null);
	if (typeof r == "string")
		displayMessage(r);
	return r;
};

bidix.upload.uploadRss = function(uploadParams,original,posDiv) 
{
	var callback = function(status,params,responseText,url,xhr) {
		if(status) {
			var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
			displayMessage(bidix.upload.messages.rssSaved,bidix.dirname(url)+'/'+destfile);
			bidix.upload.uploadMain(params[0],params[1],params[2]);
		} else {
			displayMessage(bidix.upload.messages.rssFailed);			
		}
	};
	// do uploadRss
	if(config.options.chkGenerateAnRssFeed) {
		var rssPath = uploadParams[1].substr(0,uploadParams[1].lastIndexOf(".")) + ".xml";
		var rssUploadParams = new Array(uploadParams[0],rssPath,uploadParams[2],'',uploadParams[4],uploadParams[5]);
		var rssString = generateRss();
		// no UnicodeToUTF8 conversion needed when location is "file" !!!
		if (document.location.toString().substr(0,4) != "file")
			rssString = convertUnicodeToUTF8(rssString);	
		bidix.upload.httpUpload(rssUploadParams,rssString,callback,Array(uploadParams,original,posDiv));
	} else {
		bidix.upload.uploadMain(uploadParams,original,posDiv);
	}
};

bidix.upload.uploadMain = function(uploadParams,original,posDiv) 
{
	var callback = function(status,params,responseText,url,xhr) {
		var log = new bidix.UploadLog();
		if(status) {
			// if backupDir specified
			if ((params[3]) && (responseText.indexOf("backupfile:") > -1))  {
				var backupfile = responseText.substring(responseText.indexOf("backupfile:")+11,responseText.indexOf("\n", responseText.indexOf("backupfile:")));
				displayMessage(bidix.upload.messages.backupSaved,bidix.dirname(url)+'/'+backupfile);
			}
			var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
			displayMessage(bidix.upload.messages.mainSaved,bidix.dirname(url)+'/'+destfile);
			store.setDirty(false);
			log.endUpload("ok");
		} else {
			alert(bidix.upload.messages.mainFailed);
			displayMessage(bidix.upload.messages.mainFailed);
			log.endUpload("failed");			
		}
	};
	// do uploadMain
	var revised = bidix.upload.updateOriginal(original,posDiv);
	bidix.upload.httpUpload(uploadParams,revised,callback,uploadParams);
};

bidix.upload.httpUpload = function(uploadParams,data,callback,params)
{
	var localCallback = function(status,params,responseText,url,xhr) {
		url = (url.indexOf("nocache=") < 0 ? url : url.substring(0,url.indexOf("nocache=")-1));
		if (xhr.status == 404)
			alert(bidix.upload.messages.storePhpNotFound.format([url]));
		if ((bidix.debugMode) || (responseText.indexOf("Debug mode") >= 0 )) {
			alert(responseText);
			if (responseText.indexOf("Debug mode") >= 0 )
				responseText = responseText.substring(responseText.indexOf("\n\n")+2);
		} else if (responseText.charAt(0) != '0') 
			alert(responseText);
		if (responseText.charAt(0) != '0')
			status = null;
		callback(status,params,responseText,url,xhr);
	};
	// do httpUpload
	var boundary = "---------------------------"+"AaB03x";	
	var uploadFormName = "UploadPlugin";
	// compose headers data
	var sheader = "";
	sheader += "--" + boundary + "\r\nContent-disposition: form-data; name=\"";
	sheader += uploadFormName +"\"\r\n\r\n";
	sheader += "backupDir="+uploadParams[3] +
				";user=" + uploadParams[4] +
				";password=" + uploadParams[5] +
				";uploaddir=" + uploadParams[2];
	if (bidix.debugMode)
		sheader += ";debug=1";
	sheader += ";;\r\n"; 
	sheader += "\r\n" + "--" + boundary + "\r\n";
	sheader += "Content-disposition: form-data; name=\"userfile\"; filename=\""+uploadParams[1]+"\"\r\n";
	sheader += "Content-Type: text/html;charset=UTF-8" + "\r\n";
	sheader += "Content-Length: " + data.length + "\r\n\r\n";
	// compose trailer data
	var strailer = new String();
	strailer = "\r\n--" + boundary + "--\r\n";
	data = sheader + data + strailer;
	if (bidix.debugMode) alert("about to execute Http - POST on "+uploadParams[0]+"\n with \n"+data.substr(0,500)+ " ... ");
	var r = doHttp("POST",uploadParams[0],data,"multipart/form-data; ;charset=UTF-8; boundary="+boundary,uploadParams[4],uploadParams[5],localCallback,params,null);
	if (typeof r == "string")
		displayMessage(r);
	return r;
};

// same as Saving's updateOriginal but without convertUnicodeToUTF8 calls
bidix.upload.updateOriginal = function(original, posDiv)
{
	if (!posDiv)
		posDiv = locateStoreArea(original);
	if((posDiv[0] == -1) || (posDiv[1] == -1)) {
		alert(config.messages.invalidFileError.format([localPath]));
		return;
	}
	var revised = original.substr(0,posDiv[0] + startSaveArea.length) + "\n" +
				store.allTiddlersAsHtml() + "\n" +
				original.substr(posDiv[1]);
	var newSiteTitle = getPageTitle().htmlEncode();
	revised = revised.replaceChunk("<title"+">","</title"+">"," " + newSiteTitle + " ");
	revised = updateMarkupBlock(revised,"PRE-HEAD","MarkupPreHead");
	revised = updateMarkupBlock(revised,"POST-HEAD","MarkupPostHead");
	revised = updateMarkupBlock(revised,"PRE-BODY","MarkupPreBody");
	revised = updateMarkupBlock(revised,"POST-SCRIPT","MarkupPostBody");
	return revised;
};

//
// UploadLog
// 
// config.options.chkUploadLog :
//		false : no logging
//		true : logging
// config.options.txtUploadLogMaxLine :
//		-1 : no limit
//      0 :  no Log lines but UploadLog is still in place
//		n :  the last n lines are only kept
//		NaN : no limit (-1)

bidix.UploadLog = function() {
	if (!config.options.chkUploadLog) 
		return; // this.tiddler = null
	this.tiddler = store.getTiddler("UploadLog");
	if (!this.tiddler) {
		this.tiddler = new Tiddler();
		this.tiddler.title = "UploadLog";
		this.tiddler.text = "| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |";
		this.tiddler.created = new Date();
		this.tiddler.modifier = config.options.txtUserName;
		this.tiddler.modified = new Date();
		store.addTiddler(this.tiddler);
	}
	return this;
};

bidix.UploadLog.prototype.addText = function(text) {
	if (!this.tiddler)
		return;
	// retrieve maxLine when we need it
	var maxLine = parseInt(config.options.txtUploadLogMaxLine,10);
	if (isNaN(maxLine))
		maxLine = -1;
	// add text
	if (maxLine != 0) 
		this.tiddler.text = this.tiddler.text + text;
	// Trunck to maxLine
	if (maxLine >= 0) {
		var textArray = this.tiddler.text.split('\n');
		if (textArray.length > maxLine + 1)
			textArray.splice(1,textArray.length-1-maxLine);
			this.tiddler.text = textArray.join('\n');		
	}
	// update tiddler fields
	this.tiddler.modifier = config.options.txtUserName;
	this.tiddler.modified = new Date();
	store.addTiddler(this.tiddler);
	// refresh and notifiy for immediate update
	story.refreshTiddler(this.tiddler.title);
	store.notify(this.tiddler.title, true);
};

bidix.UploadLog.prototype.startUpload = function(storeUrl, toFilename, uploadDir,  backupDir) {
	if (!this.tiddler)
		return;
	var now = new Date();
	var text = "\n| ";
	var filename = bidix.basename(document.location.toString());
	if (!filename) filename = '/';
	text += now.formatString("0DD/0MM/YYYY 0hh:0mm:0ss") +" | ";
	text += config.options.txtUserName + " | ";
	text += "[["+filename+"|"+location + "]] |";
	text += " [[" + bidix.basename(storeUrl) + "|" + storeUrl + "]] | ";
	text += uploadDir + " | ";
	text += "[[" + bidix.basename(toFilename) + " | " +toFilename + "]] | ";
	text += backupDir + " |";
	this.addText(text);
};

bidix.UploadLog.prototype.endUpload = function(status) {
	if (!this.tiddler)
		return;
	this.addText(" "+status+" |");
};

//
// Utilities
// 

bidix.checkPlugin = function(plugin, major, minor, revision) {
	var ext = version.extensions[plugin];
	if (!
		(ext  && 
			((ext.major > major) || 
			((ext.major == major) && (ext.minor > minor))  ||
			((ext.major == major) && (ext.minor == minor) && (ext.revision >= revision))))) {
			// write error in PluginManager
			if (pluginInfo)
				pluginInfo.log.push("Requires " + plugin + " " + major + "." + minor + "." + revision);
			eval(plugin); // generate an error : "Error: ReferenceError: xxxx is not defined"
	}
};

bidix.dirname = function(filePath) {
	if (!filePath) 
		return;
	var lastpos;
	if ((lastpos = filePath.lastIndexOf("/")) != -1) {
		return filePath.substring(0, lastpos);
	} else {
		return filePath.substring(0, filePath.lastIndexOf("\\"));
	}
};

bidix.basename = function(filePath) {
	if (!filePath) 
		return;
	var lastpos;
	if ((lastpos = filePath.lastIndexOf("#")) != -1) 
		filePath = filePath.substring(0, lastpos);
	if ((lastpos = filePath.lastIndexOf("/")) != -1) {
		return filePath.substring(lastpos + 1);
	} else
		return filePath.substring(filePath.lastIndexOf("\\")+1);
};

bidix.initOption = function(name,value) {
	if (!config.options[name])
		config.options[name] = value;
};

//
// Initializations
//

// require PasswordOptionPlugin 1.0.1 or better
bidix.checkPlugin("PasswordOptionPlugin", 1, 0, 1);

// styleSheet
setStylesheet('.txtUploadStoreUrl, .txtUploadBackupDir, .txtUploadDir {width: 22em;}',"uploadPluginStyles");

//optionsDesc
merge(config.optionsDesc,{
	txtUploadStoreUrl: "Url of the UploadService script (default: store.php)",
	txtUploadFilename: "Filename of the uploaded file (default: in index.html)",
	txtUploadDir: "Relative Directory where to store the file (default: . (downloadService directory))",
	txtUploadBackupDir: "Relative Directory where to backup the file. If empty no backup. (default: ''(empty))",
	txtUploadUserName: "Upload Username",
	pasUploadPassword: "Upload Password",
	chkUploadLog: "do Logging in UploadLog (default: true)",
	txtUploadLogMaxLine: "Maximum of lines in UploadLog (default: 10)"
});

// Options Initializations
bidix.initOption('txtUploadStoreUrl','');
bidix.initOption('txtUploadFilename','');
bidix.initOption('txtUploadDir','');
bidix.initOption('txtUploadBackupDir','');
bidix.initOption('txtUploadUserName','');
bidix.initOption('pasUploadPassword','');
bidix.initOption('chkUploadLog',true);
bidix.initOption('txtUploadLogMaxLine','10');


// Backstage
merge(config.tasks,{
	uploadOptions: {text: "upload", tooltip: "Change UploadOptions and Upload", content: '<<uploadOptions>>'}
});
config.backstageTasks.push("uploadOptions");


//}}}

/***
|''Name:''|XCaseListPlugin|
|''Description:''|Adds a new command ''xCase'' to the core list macro|
|''Author:''|Mario Pietsch|
|''Version:''|0.3|
|''Date:''|2010.08.03|
|''Status:''|''beta''|
|''Source:''|http://apm-plugins.tiddlyspot.com/#XCaseListPlugin|
|''License''|[[MIT License]]|
|''CoreVersion:''|2.5.0|
|''Requires:''||
|''Documentation:''|this file|
|''Keywords:''|list, sort, not case sensitive, filter|

!Description
This plugin performs a alphabetical sort for tiddlers. Default it is not case sensitive. That means ab = AB = aB = Ab! And it does some little more filtering using the RegExp syntax. The RegExp Syntax can be a little bit tricky to read and configure. But the best description I have found is at [[regular-expressions.info]]

!!!Example
{{{
<<list xCase title '[m]'>>
}}}
< <list xCase title '[m]'>>

!Default Format
{{{
<<list xCase>>
}}}

!More Possibilities
<<<
!!!Reverse sort order
{{{
<<list xCase -title >>
}}}

!!!Some basic filtering
*Every tiddler title, that starts with a number from 0 to 9.
{{{
<<list xCase title '[0-9]'>>
}}}

*Every tiddler title, that starts with an ''"a"'' or ''"b"'' or ''"c"''.
{{{
<<list xCase title '[abc]'>>
}}}

*Every tiddler title, that starts with exactly ''abc''.
{{{
<<list xCase title 'abc'>>
}}}
<<<

!!!Some advanced filtering
<<<
*same as above but with a tagList for additional filtering.
*adding the tag filter will disable the "excludeLists" setting !!
**If you need excludeLists, than you have to define it with the expression.
*XCaseListPlugin should be compatible to [[MatchTagsPlugin]] from TiddlyTools!

{{{
<<list xCase title '[a]' "[tag[MyTag]]">>
}}}

!!!Global / Local Settings
|<<option chkXCaseListCaseSensitive>> Global sort case sensitive |Sets case sensitiv sort globally|
|<<option chkXCaseListCheckField>> Sortfield defines case sensitive |Ignores global setting. Evaluates sortField and sets the value everytime <br> {{{<<list xCase sortField ..>>}}} is executed.|

If sortField is eg: 'title' .. not case sensitive (default).
if sortField is eg: 'Title' or 'TITLE' .. case sesitive sort is active.

<<<

!Code
***/

/*{{{*/

if(!version.extensions.XCaseListPlugin) { //# ensure that the plugin is only installed once
version.extensions.XCaseListPlugin = { installed: true };

config.macros.list.xCase = {};
config.macros.list.xCase.handler = function(params){

	var lookupField = 'tags';
	var lookupValue = 'excludeLists';
	var lookupMatch = false;
	
	var sortField = params[1] || '+title';
	
	// global setting for case sensitive search
	var caseSensitive = config.options.chkXCaseListCaseSensitive || false;
	var chkSortField = config.options.chkXCaseListCheckField || false;

	// if this option is active the macro parameter sortField is parsed
	// global setting is ignored !!
	if (chkSortField) caseSensitive = (sortField != sortField.toLowerCase());	
	sortField = sortField.toLowerCase();

	// check if numberedText called this macro.
	// this parameter is used by <<list numberedText ..>> macro
	// if you directly use it, it will return an unsorted list !!!
	var numberedText = false;
	if (sortField.substr(0, 1)== '#') {
		numberedText = true;
		sortField = sortField.substr(1);
		caseSensitive = false;
	}

	// check for ascending or descending sort order		
	var asc = 1;
	switch (sortField.substr(0, 1)) {
		case "-":
			asc = -1;
		case "+":
			sortField = sortField.substr(1);
			break;
		default:	;
	}	
	
	var results = [];
	var tmpResults = [];
	
	// set the default for regExp filtering
	var regSnip = params[2] || '.';	
	var regExp = new RegExp('^' + regSnip, 'im');
	var match = null;

	// check if [tag[...]] is set
	var tagList = params[3] || '';		 
	var tagMatch = tagList.length != 0;		// if list is empty everything is valid.

	if (tagMatch) {
		tmpResults = store.filterTiddlers(params[3]);
		for (var i=0, max=tmpResults.length; i<max; i++){
//			match = tmpResults[i][sortField].match(regExp);
			match = tmpResults[i].title.match(regExp);
			if (match) results.push(tmpResults[i]);			
		}; // for ..
	}
	else {
		store.forEachTiddler(function(title, tiddler){
			var f = !lookupMatch;
			for (var lookup = 0; lookup < tiddler[lookupField].length; lookup++) {
				if (tiddler[lookupField][lookup] == lookupValue) {
					f = lookupMatch;
				}
			}; // for.. 
			if (f) {
//				match = tiddler[sortField].match(regExp);
				match = tiddler.title.match(regExp);
				if (match) results.push(tiddler);
			}; // if (f) ..
		}); // store.forEach ..
	}; // else ..
	
	if (TiddlyWiki.isStandardField(sortField)) {

		if (caseSensitive) {
			results.sort(function(a, b){
				return a[sortField] < b[sortField] ? -asc : a[sortField] == b[sortField] ? 0 : asc;
			}); // results.sort
		}
		else if (numberedText) {
			// do nothing, return the list, for further processing !	
		}
		else {
			results.sort(function(a, b){
				return a[sortField].toLowerCase() < b[sortField].toLowerCase() ? -asc : a[sortField].toLowerCase() == b[sortField].toLowerCase() ? 0 : asc;
			}); // results.sort
		}; // if
	}
	else {
		results.sort(function (a, b) {
			var aField = (a.fields[sortField]) ? a.fields[sortField] : 'zzz';
			var bField = (b.fields[sortField]) ? b.fields[sortField] : 'zzz';

			return aField.toLowerCase() < bField.toLowerCase() ? -asc : aField.toLowerCase() == bField.toLowerCase() ? 0 : +asc;
			});
	}
	return results;
}
} //# end of "install only once"

/*}}}*/
/***
|''Name:''|XListPlugin|
|''Description:''|Provides a {{{<<xList>>}}} macro, that prepares the list for drag and drop sorting|
|''Author:''|Mario Pietsch|
|''Version:''|0.2.0|
|''Date:''|2010.08.03|
|''Status:''|''beta''|
|''Source:''|http://apm-plugins.tiddlyspot.com/#XListPlugin|
|''License''|[[MIT License]]|
|''CoreVersion:''|2.5.0|
|''Requires:''|XCaseListPlugin |
|''Documentation:''|this file|
|''Keywords:''|list extended sort filter|
!!!Description
<<<
This macro is only needed if you want to use [[StylingPackage]]!

!!!!UseCase
{{{
<<xList xCase [prefix] [regExp] [tag]>>
}}}
>*prefix .. can be any string. Default is "sort."
>*regExp .. can be any valid regExp, that runs against the tiddler title. Default is "." (any char except linebreaks)
>*tag .. "[tag[myTag]]" ''If you have spaces inside the tag, it has to be covered inside double quotes !!''
{{{
eg:
<<xList xCase "sort." "." "[tag[with spaces]]">>
}}}
>The above configuration will produce a custom field named {{{sort.with.spaces}}}. Because custom fields have to be lower case and spaces are not allowed. Since the tag name is used for the custom field, one tiddler can be part of different sorted lists. 
<<<

!!!Play with it
[[XListPluginTest]]

!!!ToDo
<<<
*Test together with MatchTagsPlugin
<<<

!!!History
<<<
*V 0.2.0 - 2010.08.03
**initial release
<<<

***/
/*{{{*/
config.macros.xList = {};
config.macros.xList.xCase = config.macros.list.xCase;

config.macros.xList.handler = function(place,macroName,params)
{
	var type = params[0] || "xCase";
	var sortField = params[1]  || "sort.";
	var tag = params[2] || ".";
	var tag = params[3] || "";

	tag = tag.toLowerCase();
	sortField = sortField.toLowerCase();

	var match = tag.match(/tag *\[(.+) *\] *\]/im);		// get the tag text
	if (match != null) tag = match[1];

	var res = tag.replace(/^\s+|\s+$/g, ""); 		// remove whitespace start and end
	if (res != null) tag = res;

	res = tag.replace(/ +/g, ".");				// replace spaces with a dot 
	if (res != null) tag = res;

	params[1] = sortField+tag;

	var list = document.createElement("ul");

	list.setAttribute('class', 'xList');
	list.setAttribute('tag', tag);
	list.setAttribute('sortfield', sortField);
	place.appendChild(list);
	if(this[type].prompt) {
		createTiddlyElement(list,"li",null,"listTitle",this[type].prompt);
	}
	var results;
	if(this[type].handler) {
// console.log('params: ', params)
		results = this[type].handler(params);
	}
	var li;
	for(var t = 0; t < results.length; t++) {
		li = document.createElement("li");
		li.setAttribute('id', typeof results[t] == "string" ? results[t] : results[t].title);
		list.appendChild(li);
		createTiddlyLink(li,typeof results[t] == "string" ? results[t] : results[t].title,true);
	}
};
/*}}}*/
{{{
<<xList xCase "sort." "." "[tag[with spaces]]">>
}}}
<<xList xCase "sort." "." "[tag[with spaces]]">>
{{dp50{
{{{
<<list filter "[tag[with spaces]][sort[sort.with.spaces]]">>
}}}
<<list filter "[tag[with spaces]][sort[sort.with.spaces]]">>}}}{{dp50{
{{{
<<list filter "[tag[with spaces]][sort[-sort.with.spaces]]">>
}}}
<<list filter "[tag[with spaces]][sort[-sort.with.spaces]]">>}}}


{{dp50 noBullets{
{{{
{{noBullets{ <<xList xCase "sort." "." "[tag[withoutSpaces]]">> }}}
}}}
<<xList xCase "sort." "." [tag[withoutSpaces]]>>}}}{{dp50{
{{{
<<xList xCase "-sort." "." "[tag[withoutSpaces]]">>
}}}
<<xList xCase "-sort." "." [tag[withoutSpaces]]>>}}}
Field {{{"sort.with.spaces"}}}: <<view "sort.with.spaces">>
Field {{{"sort.withoutspaces"}}}: <<view "sort.withoutspaces">>
Field {{{"sort.with.spaces"}}}: <<view "sort.with.spaces">>
Field {{{"sort.withoutspaces"}}}: <<view "sort.withoutspaces">>
Field {{{"sort.with.spaces"}}}: <<view "sort.with.spaces">>
Field {{{"sort.withoutspaces"}}}: <<view "sort.withoutspaces">>
!Using Regular Expressions with ~JavaScript ..
http://www.regular-expressions.info/javascript.html
/*{{{*/
if (config.options.txtTheme == '') config.options.txtTheme = 'TWTopListTheme';
/*}}}*/