<!--{{{-->
<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]];}

.sparkline {background:[[ColorPalette::PrimaryPale]]; border:0;}
.sparktick {background:[[ColorPalette::PrimaryDark]];}

.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]];}

#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 0em 1em 1em; left:-1px; top:-1px;}
.headerForeground {position:absolute; padding:4.5em 0em 1em 1em; left:0px; top:0px;}

.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:0em 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 .3em 0;}
#sidebarTabs .tabContents {width:15em; overflow:hidden;}

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

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

.tiddlerPopupButton {padding:0.2em 0.2em 0.2em 0.2em;}
.popupTiddler {position: absolute; z-index:300; padding:1em 1em 1em 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 0em;}
.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 0em 0em 0.5em;}
.tab {margin:0em 0em 0em 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 0em 14em;}

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

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

.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:0em 0.25em; padding:0em 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:0px 3px 0px 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 0em; font-size:.9em;}
.editorFooter .button {padding-top:0px; padding-bottom:0px;}

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

.sparkline {line-height:1em;}
.sparktick {outline:0;}

.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 0.3em 0.5em;}
#backstageToolbar {position:relative;}
#backstageArea a {font-weight:bold; margin-left:0.5em; padding:0.3em 0.5em 0.3em 0.5em;}
#backstageButton {display:none; position:absolute; z-index:175; top:0em; right:0em;}
#backstageButton a {padding:0.1em 0.4em 0.1em 0.4em; margin:0.1em 0.1em 0.1em 0.1em;}
#backstage {position:relative; width:100%; z-index:50;}
#backstagePanel {display:none; z-index:100; position:absolute; width:90%; margin:0em 3em 0em 3em; padding:1em 1em 1em 1em;}
.backstagePanelFooter {padding-top:0.2em; float:right;}
.backstagePanelFooter a {padding:0.2em 0.4em 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 1em;}
/* Fixes a feature in Firefox 1.5.0.2 where print preview displays the noscript content */
noscript {display:none;}
}
/*}}}*/
<!--{{{-->
<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'></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>>
<<mgtdList startTag:Project title:'Projects with no area' tags:'!Complete' view:Project mode:global
	group:ProjectStatus
	gView:bold
	where:tiddler.hasNoParent('Area')
	>>
<<mgtdList startTag:Action title:'You should give these actions a context' tags:'!Done' view:DoneAction mode:global
	where:tiddler.hasNoParent('Context')
	>>
<<mgtdList startTag:Action title:'Actions with no project' tags:'!Done' view:DoneAction mode:global
	where:tiddler.hasNoParent('Project')
	>>

{{cols2{

{{col{

}}}

{{col{

}}}

}}}

Enter projects and actions here. Click 'create these items' to create them.
Example usage:
{{{
Paint House
.Buy ladder and brushes|@Errand
.Choose colours|@Home|W
}}}
By default actions are next actions. 
Specify W or F to make them future or Waiting For. You can create multiple projects and project-less actions.

You can also specify area for projects. Order dosn't matter, as there can only be one uniquely named tiddler. The following is valid:
{{{
Paint House|Home Maintenance|Personal
.Buy ladder and brushes|@Errand
.Choose colours|W|@Home
}}}
To specify multiple projects and tasks, along with project-less actions, the below is an example of one way create two projects with tasks, and then a stand alone action.
{{{
Clean up yard|Personal|Home Maintenance
.Pick up sticks|@Weekend
.Bag all the sticks|@Weekend
Check out latest SAN offerings|Research|Work
.Read up on all major vendors offerings|@Reading
.Call Doug for opinion|@Call
.Check budget|@Work|F

.Call Tara about tickets
}}}
If you want to add an action to an already existing project, you can specify the project name to do so:
{{{
.Pick up lumber at Home Depot|Build toolshed|@Errand
}}}


{{cols2{

{{col{

<<tiddler 'Ticklers Requiring Action'>>

<<mgtdList
	title:'Next Actions'
	startTag:Action tags:'Next && !Done'
	view:ActionProj
	mode:global
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Next'
>>

<<mgtdList
	title:'Waiting Actions'
	startTag:Action
	tags:'[(Waiting For)] && !Done'
	view:ActionProj
	mode:global
	where:tiddler.hasActiveProject()
	newButtonTags:'Action [(Waiting For)]'
>>

}}}

{{col{

<<mgtdList
	title:'Future Actions'
	startTag:Action
	tags:'Future && !Done'
	view:ActionProj
	mode:global
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Future'
>>

{{scroll10{

<<mgtdList
	title:'Done Actions'
	startTag:Action
	tags:'Done'
	view:DoneAction
	mode:global
	newButtonTags:'Action Next Done'
	sort:-modified
>>

}}}

}}}

}}}
{{cols2{

{{col{

<<tiddler 'Ticklers Requiring Action'>>

<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:Action mode:global
	group:Contact
	gView:bold
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Next'
	>>

<<mgtdList title:'Waiting Actions' startTag:Action tags:'[(Waiting For)] && !Done' view:Action mode:global
	group:Contact
	gView:bold
	where:tiddler.hasActiveProject()
	newButtonTags:'Action [(Waiting For)]'
	>>

}}}

{{col{

<<mgtdList title:'Future Actions' startTag:Action tags:'Future && !Done' view:Action mode:global
	group:Contact
	gView:bold
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Future'
	>>


{{scroll10{

<<mgtdList title:'Done Actions' startTag:Action tags:'Done' view:DoneAction mode:global
	group:Contact
	gView:bold
	sort:-modified
	newButtonTags:'Action Next Done'
	where:tiddler.hasActiveProject()
	>>

}}}

}}}

}}}
{{cols2{

{{col{

<<tiddler 'Ticklers Requiring Action'>>

<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
	group:Context
	gView:Context
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Next'
	>>

<<mgtdList title:'Waiting Actions' startTag:Action tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
	group:Context
	gView:Context
	where:tiddler.hasActiveProject()
	newButtonTags:'Action [(Waiting For)]'
	>>

}}}

{{col{

<<mgtdList title:'Future Actions' startTag:Action tags:'Future && !Done' view:ActionProj mode:global
	group:Context
	gView:Context
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Future'
	>>

{{scroll10{

<<mgtdList title:'Done Actions' startTag:Action tags:'Done' view:DoneAction mode:global
	newButtonTags:'Action Next Done'
	sort:-modified
>>

}}}

}}}

}}}
{{cols2{

{{col{

<<tiddler 'Ticklers Requiring Action'>>

<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:Action mode:global
	group:Project
	gView:bold
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Next'
	>>

<<mgtdList title:'Waiting Actions' startTag:Action tags:'[(Waiting For)] && !Done' view:Action mode:global
	group:Project
	gView:bold
	where:tiddler.hasActiveProject()
	newButton:'Action [(Waiting For)]'
	>>

}}}

{{col{

<<mgtdList title:'Future Actions' startTag:Action tags:'Future && !Done' view:Action mode:global
	group:Project
	gView:bold
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Future'
	>>


{{scroll10{

<<mgtdList title:'Done Actions' startTag:Action tags:'Done' view:DoneAction mode:global
	group:Project
	gView:bold
	sort:-modified
	newButtonTags:'Action Next Done'
	where:tiddler.hasActiveProject()
	>>

}}}

}}}

}}}
order:1
button:a
buttonLong:active
<<mgtdList startTag:Project title:'You must assign a next action to these projects (or make them into Someday/Maybe)'
	tags:'!Complete && !Someday/Maybe' view:Project mode:global
	where:!tiddler.hasNextActionOrSubProject()
	>>
1=Practice
2=Game
3=Clinic
4=Playoff
5=Exhibition
6=Tournament
7=Semi-Final
8=Final
9=Sortout
10=Tryout
11=ICE FOR SALE
12=Other
13=Playdown
20=Summer Hockey
21=Off-ice Training


UPDATE `gl_jj_venue` SET isOurs=1 WHERE venueID=32
could do WHERE name='Jim Durrell 2'
calls jjProgramNameForID and $_TABLES is not defined, so causes SQL error
*Removed requireOnce for lib-jems.php from functions.inc. It must be included elsewhere? lib-common.php?

Part of Teams link?
Enter information about:
Police Check (date)
Offence Declaration Form (date) -- used in between years when no current police check
Speak Out! (date)
Coach's Course (date, city/prov, #) : http://mail.google.com/mail/#search/certification+ogha/11308bf3e001cf46
Trainer's Course (date, city/prov, #, expiry)

Volunteer forms?

Include survey responses from previous years?
*Change the memberID in jj_family
*If new main contact doesn't have an addressID, take it from old main and remove that one
Extend poll plugin to include more questions?
Integrate with volunteer and team pages


Evaluators use pinhey lists
Assign a rating for different aspects: skating, shooting, passing
Average the different categories, evaluators, tryouts to reach a rating

(derive from Mother/Father)
Family Roles:
**Father
**Mother
**Guardian
**Player
**Other (Supporter/Volunteer)
*language/english.php: instructionsView . "Use the Excel button below to import the schedule into another calendar app (e.g., Google calendar). Use the link button to get the URL for a particular schedule view (e.g., your team)."

Use same interface as for schedule
Allow sort by various fields & search
jj_schedule: Add aka field
Have to check for the following tables for members who created a full account:
users
jj_member
jj_family
jj_family_assignment
jj_player
jj_season_family
jj_season_player?
jj_address
jj_phone

For members who haven't logged in:
Copy email to alternate?
Delete from users table
Find memberID in jj_member, delete
Find familyID in jj_family, delete
Delete from jj_family_assignment

**register/index.php|listPlayers
**functions.inc|plugin_getPlayerField_register
When main contact is a player, the team list doesn't show the player's address etc.
account.php|listAccounts: Use register_getAccountFilter and add the Show button by brute force.


Janet, I was just on the schedule admin page, making a change to the note columns for the conditioning clinics and there are no group numbers in the 'team' drop down box, so it gives me an error, but allows the save anyway, but then the group number no longer shows up. You must have gone in the back door and put the group numbers in, I've only got the key to the front door!
 
http://mail.google.com/mail/?shva=1#inbox/11b5cd6e463edcab
List players by level or team only
Allow add/delete of players from list -- affects registration # based on season_team min/max
Competitive team min: 13 skaters + 1 goalie (14)
max: 15 skaters + 2 goalies (17)
Base numbers on defined teams and min/max

Permissions to only allow coaches from each level to view player details
View for manager or coach?

Fields: Name, DOB, Experience, Rating
Include information such as Jersey #, evaluation, previous season comments?
Notes field

Allow various printouts: choose fields, choose font & font size

Teams:
Novice 16
Atom 14-16/17
Peewee: 2 comp 14 & 15
Bantam: 3 comp 14, 15, 15
Midget: A 17

Player Status: Competitive, House League, Level, Division, Cut, Borderline,
This would move them between the lists
Have a cut checkmark
https://notes.htgsports.com/Tourneys.nsf/Reg?OpenForm&ParentUNID=F878DE10BE4F3B94852574DD0057AF37&lang=en
In terms of finding out who hasn't registered yet, it might make sense for next year to include all players from last year in the registration list with status as Unregistered. Then you would be able to filter for that.
Add a filter on Players to show those who registered last year, but haven't yet this year.

http://mail.google.com/mail/?shva=1#label/Web-OGHA/11ba4537a9c22286
Requirement: Be able to specify all Bantam HL teams at once (and to select from list). And to have the event show in all Bantam team schedules.
Idea: Make new teamIDs that are levelID * 10000 (with plus one for Comp). This way we can specify more than three teams. Need to convert back and forth between that representation and the actual teamIDs.

Also: Multi-select teams from different levels (e.g., for families with more than one player to see schedules together).

Plus: Have a teamID that represents all teams (for banquet and other joint events).
A way to enter multiple ice times at a rink in one shot (ie. 6-11pm at McNabb in one entry instead of 5 separate entries, and even better, all 30 dates that these 5 ice times occur in one entry instead of 150 entries). Please start dreaming up ways to do this, it would be really helpful as a huge timesaver and it would likely reduce the number of entry errors as well
Submission Functions: http://www.geeklog.net/docs/plugin.html#How_Geeklog_Installs_Plugins
Add link to Family Page: Set Main Contact
Have dropdown list of members. Note that main contact must have site membership (this implies an email address). So only show members who have site membership. Include instructions about them having to join and supplying a valid email. Main contact will set their email if it's blank. When they join they should choose: Join An Existing Family and use that email address.
admin/register/index.php?mode=edit
Looks as though registerID is initialized properly via $POST?

gl/register/templates/admin/editor.thtml
Had programID rather than registerID for hidden field
Change config.php for no authorization for new users
New families for any reason automatically approved?

1=Carleton B=Carleton University Ice House
2=Dulude=Dulude Arena
3=Fred Barrett=Fred Barrett Arena
4=McNabb=McNabb Arena
5=Sandy Hill=Sandy Hill Arena
6=Sensplex 1=Bell Sensplex
7=Sensplex 2=Bell Sensplex
8=Sensplex 3=Bell Sensplex
9=Sensplex 4=Bell Sensplex
10=St. Laurent=St. Laurent Arena  
11=Vanier=Bernard Grandma�tre Arena
13=Carleton A=Carleton University Ice House
14=Barbara Ann Scott=Barbara Ann Scott Arena
15=Beaudry=Ar�na Beaudry
16=Bell=Bell Centennial Arena
17=Belltown Dome=
18=Blackburn=Blackburn Arena
19=Bob Turner=Bob Turner Memorial Centre
20=Brewer=Brewer Arena
21=Brian Kilrea=Brian Kilrea Arena
22=Brockville 1=Brockville Memorial Civic Centre
24=Carleton Place 1=Neelin Street Community Centre
25=Cornwall=Cornwall Civic Complex
26=Cumberland=Cumberland Arena
27=Duchesnay=Ar�na Isabelle & Paul Duchesnay
28=Earl Armstrong=Earl Armstrong Arena
29=Embrun=Ar�na d`Embrun Arena
30=Goulbourn=Goulbourn Recreation Complex
31=Jack Charron=Jack Charron Arena
32=Jim Durrell 2=Jim Durrell Complex
33=KRC 1=Kanata Recreation Complex
34=KRC 2=Kanata Recreation Complex
35=Kemptville 1=North Grenville Municipal Centre
36=Merivale=Merivale Centennial Arena
37=Metcalfe=Metcalfe Community Centre
38=Minto=Minto Arena
39=Mlacak=Beaverbrook Park
40=Morrisburg=Morrisburg Arena
41=Navan=Navan Memorial Centre & Arena
42=Sportsplex 1=Nepean Sportsplex
43=Sportsplex 2=Nepean Sportsplex
44=Sportsplex 3=Nepean Sportsplex
45=Orleans 1=Bob MacQuarrie Recreation Complex
46=Osgoode=Osgoode Community Centre
47=Perth=Perth & District Community Arena
48=Potvin=J.B. Potvin Arena
49=Ray Friel 1=Ray Friel Centre
50=Ray Friel 2=Ray Friel Centre
51=Richmond=Richmond Memorial Community Centre
52=Robinson=Frank Robinson Arena
53=Rockland=Rockland Arena
54=Russell=Russell Arena
55=Sabourin=Ar�na Jean-Paul-Sabourin
56=Si Miller=Si Miller Community Arena
57=Smiths Falls 1=Smiths Falls Memorial Community ...
58=Stittsville=Stittsville & District Community Ce...
59=Tom Brown=Tom Brown Arena
60=Uplands=Uplands Arena
61=Walter Baker A=Walter Baker Sports Centre
62=Winchester=Winchester Community Centre
63=Orleans 2=Bob MacQuarrie Recreation Complex
64=U. Ottawa A=University of Ottawa Sports Complex
65=U. Ottawa B=University of Ottawa Sports Complex
66=Ray Friel 3=Ray Friel Centre
67=Walter Baker B=Walter Baker Sports Centre
68=Clarence Creek=Clarence Creek Recreation Centre
69=Maxville=Maxville Sports Complex
70=Cobden=Cobden Arena
71=Glengarry=Glengarry Sports Palace
72=Carleton Place 2=Neelin Street Community Centre
73=Centre 70=Centre 70 Arena
74=Chesterville=Chesterville & District Arena
75=Kingston=Kingston Regional Sports & Entertainme...
76=Cataraqui 2=Cataraqui Community Centre
77=Memorial 1=Kingston Memorial Centre
78=Brockville 2=Brockville Centennial Youth Arena
79=Kemptville 2=North Grenville Municipal Centre
80=Spencerville=Spencerville Arena
82=TBD
83=Strathcona 2=Strathcona Paper Centre
84=Strathcona 1=Strathcona Paper Centre
85=Cataraqui 1=Cataraqui Community Centre
86=Cook Brothers=Cook Brothers Youth Centre
87=Jim Durrell 1=Jim Durrell Complex
89=Beachburg=Beachburg Arena
90=Kinburn=West Carleton Community Complex
91=Beckwith=Beckwith Recreation Complex
93=Invista 1=Invista Centre
94=Cardinal=Cardinal & District Community Centre
96=Smiths Falls 2=Smiths Falls & District Youth Ce...
97=Invista 2=Invista Centre
98=Invista 3=Invista Centre
99=Invista 4=Invista Centre
Options:
Automatically send emails to remind players who have not registered before deadline

Add an email button (likely with checkboxes like the schedule so you can do all at once). This would send a prescribed message and add a note to the family account like: 2007-05-15 Registration reminder sent.
The note would be something like: 2007-05-20 Overdue warning sent.
For this, I would need the standard wording for each type of email sent. There would also be questions about sending subsequent warnings or reminders.

Account emails automated? Collection email

No problem John. I received her registration payment this week. I will
be depositing the first cheque this evening after work.

Cheque # 164
Dated 01MAY07
Amount $100

Thank you

Lynn


> Hi Lynn,
>
> As per my previous email, I sent Carly's registration in the mail
a
> week ago, and hope that it was received ok. The post office said it
> should have arrived earlier this week. Just thought I 'd check to make
> sure that everything was in order.
>
> Thanks, John Burnett

Ensure that it updates mailing lists (hmm... need these by program, I guess)

register/index.php '-' to '.'
lib-jems.php 613
https://www.telligent.ca/public/domainforless/dfl_members_change_info.asp
ascott
dipixx

http://mail.google.com/mail/?shva=1#inbox/11b5cdf6044adc12
UPDATE `gl_jj_player` set medicalConditions=NULL WHERE medicalConditions LIKE "%one" AND length(medicalConditions)=4

Change code to check for 'None'
register.php|registerPlayers: late1
Problem on Safari with resolving URLs

While we will allow them to register, we will have to notify them that they have equipment outstanding or funds outstanding and that their 'returning player' status will be in jeopardy if they do not return the equipment, or pay before a certain date (date to be determined based on info from Janet once she sorts through everything).In the past we haven't really had any problems, everything has been collected either by the team managers or by Janet directly. Often it is just info in my or Janet's heads and it's always been taken care of, however, I definitely think it should be kept track of and players should not be permitted to play until all outstanding debts are taken care of. Thanks for raising this, we should think about adding something to this effect to our database.
btw When you say 'try to do anything', do you mean when you use the Schedule Admin page or just going to the site? This would be a problem for people visiting the site with IE. What version of IE and Windows are you running?
I just went back in to check it out and as long as I'm not doing any 'administrative' stuff, there is no problem. In fact, since your last change, I don't get the message when I try to adjust the schedules anymore.
When I clicked on 'edit' for Banquet news story, that is when I get the following message:
A runtime Error has occurred.
Do you wish to Debug?
Line: 628
Error: Object expected
then I clicked 'no' and got the message again except
Line: 622
Error: Object expected
then I clicked 'no' and was able to go to the screen and edit the story if I wished.
So I don't think anyone else will have any problems accessing what they need, it must just be something with my computer.
I am still in the "Stone Age" when it comes to operating systems etc. I refuse to give up my Windows 98SE and it is IE version 6.00

That makes sense. I know there are issues with IE 6.00 and Javascript (the scripts that can be run through HTML). The change I made was to replace the Javascript call with a direct link (now you see the ugly underbelly on the URL line :). Still not sure why it caused you a problem with Firefox though.
Players for Atom and Peewee must be registered with OGHA since teams are not A level. Make this generic by checking for teams and seeing if there is an A-level?
Stephanie re. Lauren Cardarelli: http://mail.google.com/mail/#search/cardarelli/120a283613ea82e9
Check the possibility of no error when the year is specified for deposit date.
functions.inc|listVenues: Default to arenaMapsURL if ourURL and googleMapsURL are empty
Spence family looks like amount owing is still $575
could be problem with count(*) on Analyze page
*Sends the email but won't unsubscribe because the password is not Work [[OGHA Online Payment]]20xx, rather randomly generated. There is a convoluted method for unsubscribing without a password. For now, have it send to me (groupx-request@OGHA.info) and unsubscribe through list admin interface
http://mail.google.com/mail/?shva=1#inbox/11b5cdf6044adc12



*Remove spam members: http://ogha.info/register/port/removeSpamMembers.php
*Check for duplicate and ones with reasons
*Check returning members to ensure that uid is not NULL
*Check new member accounts to see whether they are used
*Check for empty roles in team_assignment, family_assignment
*Delete unused members: http://ogha.info/register/port/deleteMember.php?id=
DELETE FROM `gl_jj_family` WHERE memberID=
DELETE FROM `gl_jj_family_assignment` WHERE memberID=
DELETE FROM `gl_jj_member` WHERE memberID=
*Set empty medicalCondition to NULL: update gl_jj_player set medicalConditions=NULL where medicalConditions like 'none' OR medicalConditions like 'n/a'
!!Actions
Done actions older than 14 days.  <<deleteAllTagged 'Delete old actions' 'Action' '' 'Done' 'tiddler.olderThanDays(14)'>>
<<mgtdList title:'Done actions older than 14 days'
	view:DoneAction
	mode:global
	sort:-modified
	startTag:Action
	tags:'Done'
	where:'tiddler.olderThanDays(14)'
	>>
!!Ticklers
Inactive ticklers older than 14 days.  <<deleteAllTagged 'Delete old ticklers' 'Tickler' '' 'Actioned' 'tiddler.olderThanDays(14)'>>
<<mgtdList title:'Inactive ticklers older than 14 days'
	startTag:Tickler
	tags:'Actioned'
	view:Tickler
	mode:global
	sort:-tickleDate
	where:'tiddler.olderThanDays(14)'
	>>
!!Projects
Completed projects older than 14 days. (Delete individually).
<<mgtdList title:'Completed projects older than 14 days'
	mode:global
	sort:-modified
	startTag:Project
	tags:'Complete'
	view:ProjectComplete
	where:'tiddler.olderThanDays(14)'
	>>
Later, clear multiple teammates:
select * from gl_jj_player where teammate like "%,%" or teammate like "/" or teammate like ";"
? No, do it in registration process.
/***
|Name:|CloseOnCancelPlugin|
|Description:|Closes the tiddler if you click new tiddler then cancel. Default behaviour is to leave it open|
|Version:|3.0.1 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#CloseOnCancelPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
merge(config.commands.cancelTiddler,{

	handler_mptw_orig_closeUnsaved: config.commands.cancelTiddler.handler,

	handler: function(event,src,title) {
		this.handler_mptw_orig_closeUnsaved(event,src,title);
		if (!store.tiddlerExists(title) && !store.isShadowTiddler(title))
			story.closeTiddler(title,true);
	 	return false;
	}

});

//}}}

!Collect Items
* ...
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


<<saveChanges>>
<<search>>
<<closeAll>>
!!!!Description
*Add online registration for Competitive Tryouts

!!!!Notes
*Fees: $25
*If make team ''and join'', goes to team account; else forfeit
*Pay out as cheque * #players
<<mgtdList
	title:'Complete'
	mode:global
	startTag:Project
	tags:'Complete'
	view:ProjectComplete
	group:day
	gView:bold
	gSort:-title
	newButtonTags:'Project Complete'
	sort:-modified
	>>
<<tiddler 'MgtdSettings'>>
!!Theme
(Currently <<eval {{config.options.txtTheme}}>>)
<<selectTheme>>

{{tiny{
<slider Advanced>
[[modify menu|ConfigMenu]]
[[GTDComponent]]
</slider>
}}}









order:1
button:none
buttonLong:daily
<div macro="showWhenTagged 'Project'">[[TagDashboards##Project]]</div>
<div macro="showWhenTagged 'Context'">[[TagDashboards##Context]]</div>
<div macro="showWhenTagged 'Contact'">[[TagDashboards##Contact]]</div>
<div macro="showWhenTagged 'Area'">[[TagDashboards##Area]]</div>
<div macro="showWhenTagged 'Reference'">[[TagDashboards##Reference]]</div>
<div macro="showWhenTagged 'Ticklers Requiring Action'">[[TagDashboards##Ticklers Requiring Action]]</div>
<div macro="showWhenTagged 'Upcoming Ticklers '">[[TagDashboards##Upcoming Ticklers ]]</div>
/***
|''Name:''|DatePickerLibrary|
|''Description:''|DatePicker library for use with macros|
|''Author:''|Saq Imtiaz ( lewcid@gmail.com )|
|''Code Repository:''|http://svn.tiddlywiki.org/Trunk/contributors/SaqImtiaz/libraries/DatePicker.js|
|''Version:''|0.9|
|''Date:''|06/04/2007|
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|
|''~CoreVersion:''|2.3.0|
***/

// /%
//!BEGIN-PLUGIN-CODE
//{{{
function $id(n) {
	return document.getElementById(n);
}

DatePicker = {
	
	days : ['S','M','T','W','T','F','S'],
		
	cells : new Array(42),
	
	setup : function(){
		var cte = createTiddlyElement;
		var table = this.table = cte(null,"table","datePickerTable");
		table.style.display = 'none';
        document.body.appendChild(table);
		var thead = cte(table,"thead");
		var hRow = cte(thead,"tr");
		hRow.onclick = stopEvent;
		cte(hRow,"td",null,"datePickerNav","<<").onclick = DatePicker.prevm;
		cte(hRow,"td","datePickerMNS",null,null,{colSpan:"5"});
		cte(hRow,"td",null,"datePickerNav",">>",{align:"right"}).onclick=DatePicker.nextm; 
		
		var tbody = cte(table,"tbody","datePickerTableBody");
		var dayRow = cte(tbody,"tr",null,"datePickerDaysHeader");
		
		for (var i=0; i<this.days.length; i++){
			cte(dayRow,"td",null,null,this.days[i]);
		}      
	},
	
	show : function(el,dateObj,cb) {
		var me = DatePicker;
		var now = me.now = new Date();
		if (!dateObj)
			dateObj = now;
		me.root = el;
		if (cb)
			me.root.datePickerCallback = cb;
		me.scc = { m : now.getMonth(), y : now.getFullYear(), d : now.getDate() };
				
		Popup.place(el,me.table,{x:0,y:1});

		
		var cur = [dateObj.getDate(),dateObj.getMonth()+1,dateObj.getFullYear()];

		me.cc = { m : cur[1]-1, y : cur[2] };
		me.sd = { m : cur[1]-1, y : cur[2], d : cur[0] };   
		me.fillCalendar(cur[0],me.scc.d,cur[1]-1,cur[2]);
	},
	
	fillCalendar : function(hd,today,cm,cy) {
		var me = DatePicker;
		
		var sd = me.now.getDate();
		var td = new Date(cy,cm,1)
		var cd = td.getDay();

		$id('datePickerMNS').innerHTML = td.formatString('MMM YYYY')
		
		var tbody = $id('datePickerTableBody');
		removeChildren(tbody);
		var dowRow = createTiddlyElement(tbody,"tr",null,"datePickerDowRow");

		for (var d=0;d<=7;d++) {
			// dow headings
			createTiddlyElement(dowRow,"td",null,null,DatePicker.days[d]);
		}
		
		var days = (new Date(cy, cm+1, 0)).getDate();
		var day = 1;
		for (var j=1;j<=6;j++) { //rows
			var row = createTiddlyElement(tbody,"tr",null,"datePickerDayRow");
			for (var t=1; t<=7; t++) { //cells
				var d = 7 * (j-1) - (-t); //id key      
				if ( (d >= (cd -(-1))) && (d<=cd-(-(days))) ) {
					var dip = ( ((d-cd < sd) && (cm == me.scc.m) && (cy == me.scc.y)) || (cm < me.scc.m && cy == me.scc.y) || (cy < me.scc.y) );
					var htd = ( (hd != '') && (d-cd == hd) );
					var hToday = ( (today != '') && (d-cd == today) && cy == me.scc.y && cm == me.scc.m );
					if (htd)
						_class = 'highlightedDate';                
					else if (dip)
						_class = 'oldDate';
					else if (hToday && ! htd)
						_class = 'todayDate';
					else
						_class = 'defaultDate';
					if (t == 1 || t == 7) {
						// weekend
						_class += ' weekend';
					}
					var cell = createTiddlyElement(row,"td","datePickerDay"+d,_class,d-cd);
					cell.onmouseover = function(e){addClass(this,'tdover');};
					cell.onmouseout = function(e){removeClass(this,'tdover');};
					cell.onclick = me.selectDate;
					me.cells[d] = new Date(cy,cm,d-cd);
				}
				else {
					var cell = createTiddlyElement(row,"td","datePickerDay"+d,"emptyDate");
				}
				day++;
			}
			if(day > days + cd)
				break;
		} 
	},
	
	nextm : function() {
		var me = DatePicker;        
		me.cc.m += 1;
		if (me.cc.m >= 12) {
			me.cc.m = 0;
			me.cc.y++;
		}
		me.fillCalendar(me.getDayStatus(me.cc.m,me.cc.y),me.scc.d,me.cc.m,me.cc.y);
		return false;
	},
	
	prevm : function() {
		var me = DatePicker;
		me.cc.m -= 1;
		if (me.cc.m < 0) {
			me.cc.m = 11;
			me.cc.y--;
		}
		me.fillCalendar(me.getDayStatus(me.cc.m,me.cc.y),me.scc.d,me.cc.m,me.cc.y);
		return false;
	},
	
	getDayStatus : function(ccm,ccy){
		return (ccy == this.sd.y && ccm == this.sd.m)? this.sd.d : '';
	},
	
	selectDate : function(ev){
		var e = ev ? ev : window.event;
		var me = DatePicker;
		var date = me.cells[resolveTarget(e).id.substring(13,resolveTarget(e).id.length)];
		if (me.root.datePickerCallback && typeof me.root.datePickerCallback == 'function')
			me.root.datePickerCallback(me.root,date);
		$id('datePickerTable').style.display = 'none';
		return false;
	},
	
	onclick : function(ev){
		$id("datePickerTable").style.display = 'none';
		return false;
	},
	
	create : function(el,dateObj,cb){
		el.onclick = el.onfocus = function(e){DatePicker.show(el,dateObj,cb);stopEvent(e)};
	},
	
	css: "table#datePickerTable td.datePickerNav {\n"+
		"    cursor:pointer;\n"+
		"}\n"+
		"\n"+
		".datePickerDaysHeader td {\n"+
		"    text-align:center;\n"+
		"    background:#ABABAB;\n"+
		"    font:12px Arial;\n"+
		"}\n"+
		"\n"+
		".datePickerDayRow td {\n"+
		"    width:18px;\n"+
		"    height:18px;\n"+
		"}\n"+
		"\n"+
		"td#datePickerMNS, td.datePickerNav {\n"+
		"    font:bold 13px Arial;\n"+
		"}\n"+
		"\n"+
		"table#datePickerTable {\n"+
		"    position:absolute;\n"+
		"    border-collapse:collapse;\n"+
		"    background:#FFFFFF;\n"+
		"    border:1px solid #ABABAB;\n"+
		"    display:none;   \n"+
		"}\n"+
		"\n"+
		"table#datePickerTable td{\n"+
		"    padding: 3px;\n"+
		"}\n"+
		"\n"+
		"td#datePickerMNS {\n"+
		"    text-align: center;\n"+
		"}\n"+
		"\n"+
		"tr.datePickerDayRow td {\n"+
		"    background-color : #C4D3EA;\n"+
		"    cursor : pointer;\n"+
		"    border : 1px solid #6487AE;\n"+
		"    text-align : center;\n"+
		"	font : 10px Arial;\n"+
		"}\n"+
		"\n"+
		"tr.datePickerDayRow td.defaultDate {\n"+
		"	color : #333333;	\n"+
		"	text-decoration : none;   \n"+
		"}\n"+
		"\n"+
		"tr.datePickerDayRow td.emptyDate {\n"+
		"    cursor:default; \n"+
		"}\n"+
		"\n"+
		"tr.datePickerDayRow td.oldDate {\n"+
		"	color : #ABABAB;\n"+
		"    text-decoration : line-through;\n"+
		"}\n"+
		"\n"+
		"tr.datePickerDayRow td.highlightedDate {\n"+
		"    background : #FFF799;\n"+
		"	font-weight : bold;\n"+
		"	color : #333333;\n"+
		"}\n"+
		"\n"+
		"tr.datePickerDayRow td.todayDate {\n"+
		"	font-weight : bold;\n"+
		"	color : red;\n"+
		"}\n"+
		"\n"+
		"table#datePickerTable tr.datePickerDayRow td.tdover {\n"+
		"    background:#fc6;\n"+
		"}",
	
	init : function(){
		this.setup();
		addEvent(document,'click',DatePicker.onclick);
		config.shadowTiddlers['StyleSheetDatePicker'] = this.css;
		if(store)
			store.addNotification('StyleSheetDatePicker',refreshStyles);
	}
};

DatePicker.init();
//}}}
//!END-PLUGIN-CODE
// %/
Put this as a discount for OGHA players, or a fee (insurance?) for non-OGHA?
gl/register/templates/submit.thtml: Add memberDiscount
jj_register: Add memberDiscount
*functions.inc|getListSql: 
**Change dates to be from now unless month specified (don't worry about program start and end?)
**Add ALL to programs dropdown OR
**Don't use any programs except regular season, then let person select team/activity to filter
*Stephanie re. http://mail.google.com/mail/#inbox/122d22421fd1353c
**I have just entered the Intermediate A tryout sessions, but something curious has happened. The final session on Wednesday Sept 16th does not show up on the public tryout schedules and all the intermediate tryout hours are the only ones that show up on the 2009/10 public schedule.
**Is there a way to amalgamate all of the schedules and have the public schedule tab default to the 09/10 season and show conditioning, tryouts, practices and sortouts all in one place? I can see that otherwise it could be confusing to the public, actually it's even confusing to me right now.
*Stephanie re: http://mail.google.com/mail/#inbox/122ce9adc6cf48c3
**This was due to overlap of two programs' dates
**Xfunctions.inc|getFamilyRoleList: Add to if || (empty($selected) && $role == 'Father'))
**lib-custom.php: Check in custom membership
[[Next and Waiting Actions by Context]]
{{cols2{

{{col{

<<mgtdList
	title:'Delegated/Waiting For'
	startTag:Action
	tags:'[(Waiting For)] && !Done'
	view:ActionProj
	mode:global
	where:tiddler.getByIndex("Contact").length > 0'
	group:Contact
	gView:bold
	newButtonTags:'Action [(Waiting For)]'
	>>

}}}

{{col{

<<mgtdList title:'Done' startTag:Action tags:'Done && [(Waiting For)]' view:DoneAction mode:global
	where:tiddler.getByIndex('Contact').length>0
	group:Contact
	gView:bold
	newButtonTags:'Action Done [(Waiting For)]'
	>>

}}}

}}}


/***
|Name|DeleteAllTaggedPlugin|
|Based on|http://ido-xp.tiddlyspot.com/#DeleteAllTaggedPlugin|
|Version|MGTD Hacked|

An adaptation of DeleteDoneTasks (Simon Baird) by Ido Magal
To use this insert {{{<<deleteAllTagged>>}}} into the desired tiddler.

Modified quite a bit by Simon for MonkeyGTD
Now only works with MgtdIndexedTags...

Example usage:
{{{<<deleteAllTagged>>}}}
<<deleteAllTagged>>
***/
//{{{

config.macros.deleteAllTagged = {
	handler: function ( place,macroName,params,wikifier,paramString,tiddler ) {
		var buttonTitle = params[0] ? params[0] : "Delete tiddlers tagged '"+tiddler.title+"'"; // simon's tweak
		var tagToDelete = params[1] ? params[1] : tiddler.title;
		var alsoDeleteThisTiddler = params[2] ? params[2] : "";
		var tagExpr = params[3] ? params[3] : tagToDelete;
		var whereExpr = params[4] ? params[4] : "true";
		createTiddlyButton( place, buttonTitle, "Delete every tiddler tagged with '"+tiddler.title+"'",
			this.deleteAllTagged( tagToDelete, alsoDeleteThisTiddler == "delete", tagExpr, whereExpr ));
	},

	deleteAllTagged: function(tag,deleteMe,tagExpr,whereExpr) {
		return function() {
			var collected = fastTagged(tag).filterByTagExpr('[['+tagExpr+']]').filterByEval(whereExpr).toTitleList();
			if (collected.length == 0) {
				alert( "None found." );
			}
			else {
				if (confirm( "Found these tiddlers:\n'"
						+ collected.join( "', '" ) + "'\n\n\n"
						+ "Are you sure you want to delete these?" )) {
					store.suspendNotifications();
					for ( var i=0;i<collected.length;i++ ) {
						store.removeTiddler( collected[i] );
						story.closeTiddler( collected[i], true );
						displayMessage( "Deleted '"+collected[i]+"'" );
					}
					store.resumeNotifications();
				}
			}
			if (deleteMe) {
				if (confirm("Also delete this tiddler, '"+tag+"'?")) {
					store.removeTiddler( tag );
					story.closeTiddler( tag, true );
					displayMessage( "Deleted '"+tag+"'" );
				}
			}
		}
	}
};

//}}}

Create a jj_season_team table that points to the jj_team table and includes goalie/player limits. Would this work for summer registration? Want that separate so we don't lose previous season's team until necessary?
Change the Peewee B name to Peewee BB. Also change Midget BB to Midget B.
Are these new teams for the fall? Will they be in place of the existing teams?

If I change the team levels for the existing teams, the links to team pages won't work (since it pulls it from the team name). When people log in to register I'd like those links to demonstrate how useful the site could be to them :)

Would it be okay to leave them as is for now, then change them in June once most returning players have registered?

If these are new teams, I can add them. You'd then see both Peewee B and Peewee BB.

I see, these teams would replace the existing teams, the hope is to bump the Peewee B team up to BB for next season and the Midget BB never was BB, it was B last season and I don't see that changing for next season.
The only reason that I was thinking about it, was so that when people look at the tryout schedule, they see that we are planning a Peewee BB team, for the purposes of our existing players and for anyone new who might be visiting the site and be interested in the levels we offer, at a quick glance, they would see that it'll be a Peewee BB team and the same logic for the Midget team as well.
I agree with you though, that we want people to see how useful the site can be, so perhaps we make the change after May 31st then.
[[Today]]
[[Tomorrow]]
<<taskTimer today>>

[[Next Actions|Next Actions by Context]]
[[Starred Next Actions|Starred Next Actions]]
[[Next & Waiting Actions|Next and Waiting Actions by Context]]
[[Next & Waiting (Single Col)|Next and Waiting Actions by Context Single Col]]
[[Action Dashboard|Action Dashboard by Context]]
[[Starred Items]]
[[Tickler Dashboard]]
[[Delegated Tasks Dashboard]]
[[Reference Items]]
[[Done Actions]]

<slider+ Contexts>
<<mgtdList startTag:Action tags:'Next && !Done' groupCountOnly:yes group:Context gView:plain where:tiddler.hasActiveProject()>>
</slider>
<slider Grouped by Project>
[[Next Actions|Next Actions by Project]]
[[Next and Waiting Actions|Next and Waiting Actions by Project]]
[[Action Dashboard|Action Dashboard by Project]]
</slider>
<slider Ungrouped>
[[Next Actions]]
[[Next and Waiting Actions]]
[[Action Dashboard]]
</slider>
<slider All contexts>
<<mgtdList startTag:Context>>
</slider>

^^[[modify menu|DoWorkMenu]]^^
(update => lose uid) Fixed?

<<mgtdList
	title:'Done'
	mode:global
	startTag:Action
	tags:'Done'
	view:DoneAction
	group:day
	gView:DoneAction
	gSort:-title
	newButtonTags:'Action Next Done'
	sort:-modified
	>>

layout/ogha
forum??
albums
gallery (need to update this?)
register
schedule
chatterbox
calendar
...

http://mail.google.com/mail/?shva=1#inbox/11ba4537a9c22286
What I did for now was use the Excel export to get all the emails (below). I had to massage it a bit to put ; between the addresses.

    As a feature, would you prefer that email is sent through the site, or that you download a list of email addresses to use in Outlook? Another possibility is to make a mailing list (e.g., atom.2008@ogha.info) for each level as players register/withdraw. This is likely best since the list will change over time; however, it depends how often you need the list whether it's worth the work.

I really like the idea of making a mailing list for each age group, is this possible or is it a huge task? I can see several occasions where this could be used.
Allow players to play up for Fundamentals to Int; and to play down for Novice
http://mail.google.com/mail/?shva=1#inbox/11b9b4e94efe6302

functions.inc: Add $expand with default false
*register_getPlayerLevelSql: Add $expand and change ageLow, ageHigh based on levelID
*register_getListSql: Add $expand so it can be passed on

team.php|selectPlayers: Add $expand=true so list includes players from other level

desrochers@rogers.com It looks as though there is a glitch in logic re. last year's players. It may be because Jena's recent experience still shows as OWHA, although I do check first if they were on an OGHA team in the previous year.

schedule/index.php?mode=export
libgmail: http://libgmail.sf.net
Geeklog Feed Functions: http://www.geeklog.net/docs/plugin.html#How_Geeklog_Installs_Plugins
Spreadsheet lists of the registrants so that we can start analysing who is where and how many in each level etc.
Spreadsheets for checking in at the time of tryouts and sort outs.

Teams page will allow an export of player info to CSV (Excel-readable). You'll have to let me know the various formats that you need. Try out/sort out lists would be one. I think you said team lists (contact) go to the league? And there would be player evaluation info (if we get as far as evaluation data entered on the site) for the coaches?

My concern with exporting is that the data will be duplicated. We have to be sure that it is used only for printing or sending in a particular format. Once it's edited outside of the site database, there will be problems.

Export a printable view (or, in the case of MOGHL, csv) with selected fields.
Have checkboxes on column headers to choose print format (or a pop-up box)

Formats:
For competitive tryouts, list of players at each age level (name, dob, parent 1, parent 2, experience, medical, preferences)
Update as players are moved off list
Check in list with pinhey boxes (black or red columns) to put the number in
List to MOGHL in Access format (http://mail.google.com/mail/?shva=1#inbox/11c444e8b98b34aa)
List to ODWHA
List to OWHA -- ledger-size form, make labels in sections: first, last then dob with street address (Kathy has sample, Stephanie to send original form)
[[Goalie list|Kathryn re. goalie list]]
Game sheet labels (include certification # & Captain): http://mail.google.com/mail/?shva=1#inbox/11c2e7c8f0fe240f & http://mail.google.com/mail/?shva=1#inbox/11c47baf0bcd560d & http://mail.google.com/mail/?shva=1#inbox/11c662c43f2f5a25
http://mail.google.com/mail/?shva=1#inbox/11dcefc343de0775
Team cards (allow selection of different fields)
/***
|Name:|ExtentTagButtonPlugin|
|Description:|Adds a New tiddler button in the tag drop down|
|Version:|3.2 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#ExtendTagButtonPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{

window.onClickTag_mptw_orig = window.onClickTag;
window.onClickTag = function(e) {
	window.onClickTag_mptw_orig.apply(this,arguments);
	var tag = this.getAttribute("tag");
	var title = this.getAttribute("tiddler");
	// Thanks Saq, you're a genius :)
	var popup = Popup.stack[Popup.stack.length-1].popup;
	createTiddlyElement(createTiddlyElement(popup,"li",null,"listBreak"),"div");
	wikify("<<newTiddler label:'New tiddler' tag:'"+tag+"'>>",createTiddlyElement(popup,"li"));
	return false;
}

//}}}



Right now in the 'Accounts' section, it lists main contact, would it be possible to list below the main contact's name the players first and last names.
We are running into several cases where players have different names than their main contact - for example that pain in the neck Thorslund family, children go by both Thorslund and Jansen. While Lynn and I are pretty good about remembering most of the players and parents, there will be other people accessing the system who do not know the names as well. I see that in the notes you have indicated the registration date and first name of the player, but it would be nice if all the names (not the other 'members', just the registered players) could be listed below the main contact. I originally had it with the players' names in the first column, but then alphabetic ordering was difficult (e.g., with the pain-in-the-neck Jansen family). The problem is that I'm limited to what fields I can access in that type of listing. What is likely best is just to use the search box to look for a player's name. I don't think it allows search on the Notes field now, but that would solve the problem if I can do it.
Change status to Registered & Send confirmation email
Set level limits on Seasons page and auto-fill from waiting list (season.php)
Send an email whenever status is changed from Waiting List to Registered manually
Add checkboxes to Registration page to allow multiple status changes/emails at once

Add the position field to Registration page
Allow for goalies to be wait listed separately from Peewee on up
Base numbers on defined teams and min/max

Code changes:
admin/plugins/register/index.php: Add check if jjAcceptPlayer returns false.

But: sendEmail returns false and then sends the email later…hmm why is that? Q: Should I just put a link that opens Outlook for Stephanie? It would auto-fill the subject and body. Has the advantage that she could edit the email. Disadvantage that it's an extra step, and how would it update the status and notes fields?
A similar thing could work for the Accounts page with filters for overdue accounts, and a standard email reminder.
Change to assn. Same for assnYears. Note that need to upload language.php.
*jems.php|jjGetMapUrl: Change to use new format for gallery images
[[example|http://OGHA.info/register/port/getMailingList.php?id=3&team=Group6]]
functions.inc
Is there any way to have the system return to the last page you were working on rather than automatically go back to the first page? For example, I was going through the accounts last night to send out emails to those that were overdue and I went to the 2nd page, found a person, sent an email and then put a note in the 'notes' column, saved and was taken back to the first page. I guess I'm ultimately lazy, cause I started to find it annoying having to go back and choose the page after each entry that I made. 

I'll take a look at this. I thought it did return after editing, but I may have missed this with the accounts page (or it could be the issue with which fields I can access again).
http://mail.google.com/mail/?shva=1#inbox/11d80fddb7ca3e7a
http://mail.google.com/mail/?shva=1#inbox/11b43611948f78c3
*From Stephanie: http://mail.google.com/mail/#search/stephanie+poa/120e4ea96d445fab
*Alicia: http://mail.google.com/mail/#inbox/120e52f9c3056f6e
*Brooklyn: http://mail.google.com/mail/#inbox/120e857126559a8a
http://mail.google.com/mail/?shva=1#inbox/11c05e23abef5dfe
Turns out to be a problem only with entering a zero value; nothing to do with seasons!

admin/register/account.php|submitAccount:
*Tried checking is_numeric($v) to not put quotes
*Doesn't like that $actualCost doesn't have decimal value: if ($actualCost == 0) { $actualCost = "0.00"; }
*Need a way to reset to NULL after it's been set to zero: if (empty($v)'' || $v < 0'') { $v = "NULL"; }
plugins/register/templates/admin/account.thtml:
*Add note about setting to -1 => "Use -1 to clear the field"??
Carleton, Morrisburg, Richmond
Note from Stephanie re. insurance added improperly: http://mail.google.com/mail/#inbox/120a283613ea82e9
lib-jems.php|jjIsNewHockeyPlayer: checks experience in jj_player; why does it include OGHA? should check teams from most recent regular season
http://www.ogha.info/register/contact.php?registerID=4&teamID=34&view=team&roleID=player
Have it show just first names for list (with a message?)
Don't show 'no team' message when a new season is chosen

Problem since (30 Jun 07)
register.php: Shows totalFees - discounts, but not insurance and leagueFee. These aren't passed in to submitRegistration.
Temporary fix: Only show calculation for regular season ($registerID == 4)
737-7600 (used by two people?)
#Allow Atom players to play FUNdamentals
#Fix problem with Intermediate list showing all levels: it was taking levelID down 1 to Midget/Int which has age limits of 0
lib-jems.php|jjGetLevelID($
   if (FUNdamentals) go up two levels
   else if (Intermediate) go down two
   else go down one
functions.inc|register_getSummaryLine:
*Was setting mode to 'team' rather than 'export' since default $team='false' (removed quotes)
*Need to check this so it can be used for OWHA team export as well as sortouts (guess this is where the $team came in) ... maybe do it by date. If sortouts are over (after Sep ?) then use 'team'. Kinda kludgy.
register.php|registerPlayers: strtotime($regEarlyDate . ' 23:59:59 GMT') >= time()
*Check early registration discount on the date
Register.php
<= $regEarlyDate
Dory; http://mail.google.com/mail/#inbox/1241e2cc2a6eeea8


Not wait listing new players:
*Maala: http://mail.google.com/mail/#inbox/120d3f72c45d75d2


order:3
button:f
buttonLong:future
CISV key: ABQIAAAAYJeFUQnYLVaNKbb1LrrTIRSJkYlxn09_UYCA02YwEzAhlq4FQBQB0Zk6eyN_Uw7q80-8eXGP9s9sEQ
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8"/>
    <title>Google Maps JavaScript API Example</title>
    <script src="http://maps.google.com/maps?file=api&amp;v=2&amp;key=ABQIAAAAYJeFUQnYLVaNKbb1LrrTIRRzw5qOtdGXh6FDXQq7krXtkY8oxBQpVNpaMMDgo0GmJb2tkzNQh5Bqjg"
      type="text/javascript"></script>
    <script type="text/javascript">

    //<![CDATA[

    function load() {
      if (GBrowserIsCompatible()) {
        var map = new GMap2(document.getElementById("map"));
        map.setCenter(new GLatLng(37.4419, -122.1419), 13);
      }
    }

    //]]>
    </script>
  </head>
  <body onload="load()" onunload="GUnload()">
    <div id="map" style="width:500px;height:300px"></div>
  </body>
</html>

Problems with Firefox:
Have you tried emptying your browser cache?  Have you disabled all
plugins?  Have you attempted to temporarily disable your firewall (**
Use CAUTION! **)?  Have you tried everything here?
http://maps.google.com/support/bin/answer.py?answer=18529&topic=10789

And here?
http://maps.google.com/support/bin/answer.py?answer=16539&topic=10789

And here?
http://maps.google.com/support/bin/topic.py?topic=10789 
/***
|Name:|HideWhenPlugin|
|Description:|Allows conditional inclusion/exclusion in templates|
|Version:|3.1 ($Rev: 3919 $)|
|Date:|$Date: 2008-03-13 02:03:12 +1000 (Thu, 13 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#HideWhenPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
For use in ViewTemplate and EditTemplate. Example usage:
{{{<div macro="showWhenTagged Task">[[TaskToolbar]]</div>}}}
{{{<div macro="showWhen tiddler.modifier == 'BartSimpson'"><img src="bart.gif"/></div>}}}
***/
//{{{

window.hideWhenLastTest = false;

window.removeElementWhen = function(test,place) {
	window.hideWhenLastTest = test;
	if (test) {
		removeChildren(place);
		place.parentNode.removeChild(place);
	}
};


merge(config.macros,{

	hideWhen: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( eval(paramString), place);
	}},

	showWhen: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( !eval(paramString), place);
	}},

	hideWhenTagged: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( tiddler.tags.containsAll(params), place);
	}},

	showWhenTagged: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( !tiddler.tags.containsAll(params), place);
	}},

	hideWhenTaggedAny: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( tiddler.tags.containsAny(params), place);
	}},

	showWhenTaggedAny: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( !tiddler.tags.containsAny(params), place);
	}},

	hideWhenTaggedAll: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( tiddler.tags.containsAll(params), place);
	}},

	showWhenTaggedAll: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( !tiddler.tags.containsAll(params), place);
	}},

	hideWhenExists: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( store.tiddlerExists(params[0]) || store.isShadowTiddler(params[0]), place);
	}},

	showWhenExists: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( !(store.tiddlerExists(params[0]) || store.isShadowTiddler(params[0])), place);
	}},

	hideWhenTitleIs: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( tiddler.title == params[0], place);
	}},

	showWhenTitleIs: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( tiddler.title != params[0], place);
	}},

	'else': { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		removeElementWhen( !window.hideWhenLastTest, place);
	}}

});

//}}}

functions.inc: Add indication that player is not registered for regular season


It is updating the value, but not showing it checked on edit.
**Wasn't setting $allowPhoto to $A['photoConsent'] for non-new player
*Not pretty, but puts up error message and you have to go back to [[Programs Page]] or hit Back

Membership Form: http://mail.google.com/mail/?zx=1dp0xdwzgrch0&shva=1#inbox/11ca05bd41149d5f
Terms of Participation/Volunteer Form: http://mail.google.com/mail/?shva=1#inbox/11cd31a03d726e50
Translate process from OGHA:
*Handle multiple membership types: Trial, Individual, Family, Life (jj_register_family?) (set costs as discountIndividual, discountTrial, discountLife in jj_register)
*Separate discounts from register and specify testable conditions ...
*jj_program = camps/membership; Selection Camp corresponds to applying for a program; check off leader
*jj_register_team = program details (e.g., V-2009-028)
*jj_level = programs/ages
*jj_association = chapter
*jj_division = generic delegation # (e.g., Village 1)


http://dokuwiki.org
*On jems.ca/ogha
/***
|Name:|InstantTimestampPlugin|
|Description:|A handy way to insert timestamps in your tiddler content|
|Version:|1.0.10 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#InstantTimestampPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Usage
If you enter {ts} in your tiddler content (without the spaces) it will be replaced with a timestamp when you save the tiddler. Full list of formats:
* {ts} or {t} -> timestamp
* {ds} or {d} -> datestamp
* !ts or !t at start of line -> !!timestamp
* !ds or !d at start of line -> !!datestamp
(I added the extra ! since that's how I like it. Remove it from translations below if required)
!!Notes
* Change the timeFormat and dateFormat below to suit your preference.
* See also http://mptw2.tiddlyspot.com/#AutoCorrectPlugin
* You could invent other translations and add them to the translations array below.
***/
//{{{

config.InstantTimestamp = {

	// adjust to suit
	timeFormat: 'DD/0MM/YY 0hh:0mm',
	dateFormat: 'DD/0MM/YY',

	translations: [
		[/^!ts?$/img,  "'!!{{ts{'+now.formatString(config.InstantTimestamp.timeFormat)+'}}}'"],
		[/^!ds?$/img,  "'!!{{ds{'+now.formatString(config.InstantTimestamp.dateFormat)+'}}}'"],

		// thanks Adapted Cat
		[/\{ts?\}(?!\}\})/ig,"'{{ts{'+now.formatString(config.InstantTimestamp.timeFormat)+'}}}'"],
		[/\{ds?\}(?!\}\})/ig,"'{{ds{'+now.formatString(config.InstantTimestamp.dateFormat)+'}}}'"]
		
	],

	excludeTags: [
		"noAutoCorrect",
		"noTimestamp",
		"html",
		"CSS",
		"css",
		"systemConfig",
		"systemConfigDisabled",
		"zsystemConfig",
		"Plugins",
		"Plugin",
		"plugins",
		"plugin",
		"javascript",
		"code",
		"systemTheme",
		"systemPalette"
	],

	excludeTiddlers: [
		"StyleSheet",
		"StyleSheetLayout",
		"StyleSheetColors",
		"StyleSheetPrint"
		// more?
	]

}; 

TiddlyWiki.prototype.saveTiddler_mptw_instanttimestamp = TiddlyWiki.prototype.saveTiddler;
TiddlyWiki.prototype.saveTiddler = function(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created) {

	tags = tags ? tags : []; // just in case tags is null
	tags = (typeof(tags) == "string") ? tags.readBracketedList() : tags;
	var conf = config.InstantTimestamp;

	if ( !tags.containsAny(conf.excludeTags) && !conf.excludeTiddlers.contains(newTitle) ) {

		var now = new Date();
		var trans = conf.translations;
		for (var i=0;i<trans.length;i++) {
			newBody = newBody.replace(trans[i][0], eval(trans[i][1]));
		}
	}

	// TODO: use apply() instead of naming all args?
	return this.saveTiddler_mptw_instanttimestamp(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created);
}

// you can override these in StyleSheet 
setStylesheet(".ts,.ds { font-style:italic; }","instantTimestampStyles");

//}}}

Image Flow: http://www.glfusion.org/filemgmt/visit.php?lid=211

FTP: http://filezilla-project.org/

Get roles from database: http://docs.codecharge.com/studio3/html/index.html?http://docs.codecharge.com/studio3/html/ProgrammingTechniques/HowTo/WorkingWithDatabases/UtilizeMySQLEnum.html

Check for non-address for main contact:
SELECT *
FROM `gl_jj_family` AS F
LEFT JOIN gl_jj_member AS M
USING ( memberID )
WHERE M.addressID IS NULL

Get some info from CISV Leaders 2008 http://spreadsheets.google.com/ccc?key=p2VkB8ctB4Y5oodjFlz0dIw&hl=en

Get trial memberships from Sue K.

Get Sue K. to vet current membership data.

Question of secure server: http://www.geeklog.net/forum/viewtopic.php?showtopic=71900
http://www.geeklog.fr/cms/wiki/doku.php/security:hardening_your_geeklog_site

http://www.dartmouth.edu/~deploypki/deploying/PKI_Authentication_for_Geeklog.html
http://www.ourshop.com/resources/ssl.html
http://helpdesk.bluehost.com/kb/index.php?x=&mod_id=2&id=229

Tripwire: ftp://ftp.cerias.purdue.edu/pub/tools/unix/ids/tripwire/

https://secure.bluehost.com/~jemsca/cisv/

Information leaks: http://whitepapers.zdnet.com/abstract.aspx?docid=300733

Processes on Bluehost: http://helpdesk.bluehost.com/kb/index.php?x=&mod_id=2&id=318

Privacy Act
http://www.astrazeneca.ca/en/legal/privacy_statement.asp
http://www.tbs-sct.gc.ca/atip-aiprp/impl-rep/impl-rep2000/71-imp-mise-eng.asp#attachgi

Problem with date on birthdate (likely date functions changed)

Change data to utf8 from latin1 (default) ... odd characters in DokuWiki
http://www.oreillynet.com/onlamp/blog/2006/01/turning_mysql_data_in_latin1_t.html

OGHA: english.php: Add gender, middleName, nickName, middle, nick

Team Speak:http://www.glfusion.org/forum/viewtopic.php?showtopic=12704

Image Flow: http://www.glfusion.org/filemgmt/visit.php?lid=211

FTP: http://filezilla-project.org/

Get roles from database: http://docs.codecharge.com/studio3/html/index.html?http://docs.codecharge.com/studio3/html/ProgrammingTechniques/HowTo/WorkingWithDatabases/UtilizeMySQLEnum.html

Check for non-address for main contact:
SELECT *
FROM `gl_jj_family` AS F
LEFT JOIN gl_jj_member AS M
USING ( memberID )
WHERE M.addressID IS NULL

Get some info from CISV Leaders 2008 http://spreadsheets.google.com/ccc?key=p2VkB8ctB4Y5oodjFlz0dIw&hl=en

Get trial memberships from Sue K.

Get Sue K. to vet current membership data.

Question of secure server: http://www.geeklog.net/forum/viewtopic.php?showtopic=71900
http://www.geeklog.fr/cms/wiki/doku.php/security:hardening_your_geeklog_site

http://www.dartmouth.edu/~deploypki/deploying/PKI_Authentication_for_Geeklog.html
http://www.ourshop.com/resources/ssl.html
http://helpdesk.bluehost.com/kb/index.php?x=&mod_id=2&id=229

Tripwire: ftp://ftp.cerias.purdue.edu/pub/tools/unix/ids/tripwire/

https://secure.bluehost.com/~jemsca/cisv/

Information leaks: http://whitepapers.zdnet.com/abstract.aspx?docid=300733

Processes on Bluehost: http://helpdesk.bluehost.com/kb/index.php?x=&mod_id=2&id=318

Privacy Act
http://www.astrazeneca.ca/en/legal/privacy_statement.asp
http://www.tbs-sct.gc.ca/atip-aiprp/impl-rep/impl-rep2000/71-imp-mise-eng.asp#attachgi

Problem with date on birthdate (likely date functions changed) dropdown just shows 2008

Change data to utf8 from latin1 (default) ... odd characters in DokuWiki
http://www.oreillynet.com/onlamp/blog/2006/01/turning_mysql_data_in_latin1_t.html

OGHA: english.php: Add gender, middleName, nickName, middle, nick
http://mail.google.com/mail/#drafts/1154c396a02693ef
$50? Or $100 closer to Peter's price and covers membership as in OGHA?



http://ogha.info/admin/plugins/register/index.php?id=4&mode=goalie
/***
|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));
}

//}}}

Link the user info page (the one you see when you click on a logged-in user or contributor name).

<<tabs txtMGTDMore
	"Timeline" "Timeline" TabTimeline
	"MGTD" "Configuration Options" ConfigMenu
	"TW" "TiddlyWiki SideBar" TWSideBar
	>>
<<tabs txtMGTDMain
	"Work" "Do Work" DoWorkMenu
	"Review" "Review" ReviewMenu
	"Process" "Process Inbox" ProcessInboxMenu
	"More..." "More..." MGTDMoreTab
	>>
MPTW is a distribution or edition of TiddlyWiki that includes a standard TiddlyWiki core packaged with some plugins designed to improve usability and provide a better way to organise your information. For more information see http://mptw.tiddlyspot.com/.
Doesn't work in Safari on the Mac: http://mail.google.com/mail/#inbox/11c80da7d525b6fc
(Contributed by Ken Mankoff)
{{cols2{


{{col{

<<mgtdList startTag:Action title:'Next' tags:'Next && !Done'
view:Action mode:global
       group:Project
       gView:bold
       newButtonTags:'Action Next'
       where:tiddler.hasActiveProject()
       >>

<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !
Done' view:Action mode:global
       group:Project
       gView:bold
       where:tiddler.hasActiveProject()
       newButtonTags:'Action [(Waiting For)]'
       >>


}}}

{{col{

<<mgtdList title:'Starred Actions' startTag:Starred tags:'Action && !
Done' view:ActionProj mode:global
       group:ActionStatus
       gView:bold
       newButtonTags:'Starred Action'
       >>

<<mgtdList title:'Starred Projects' startTag:Starred tags:'Project && !
Complete' view:Project mode:global
       group:ProjectStatus
       gView:bold
       newButtonTags:'Starred Project'
       >>

<<mgtdList title:'Other Starred Items' startTag:Starred tags:'!Project
&& !Action' view:star mode:global
       group:GTDComponent
       gView:bold
       newButtonTags:'Starred'
       >>

!!! Last 30 Modifications
<<timeline "modified" "30" "ddd, YYYY-0MM-0DD">>

}}}

}}}

Use search for finding last name for now			
merge(Array.prototype,{

	each: function(func) {
		for (var i=0;i<this.length;i++)
			func(this[i]);
	},

	// TODO, there is a map in the core now. Is it same as this or different?
	map: function(func) {
		var result = [];
		this.each(function(item) {
			result.push(func(item));
		});
		return result;
	},

	select: function(func) {
		var result = [];
		this.each(function(item) {
			if (func(item))
				result.push(item);
		});
		return result;
	},

	reject: function(func) {
		var result = [];
		this.each(function(item) {
			if (!func(item))
				result.push(item);
		});
		return result;
	}

});

//------------------------------------------

merge(String.prototype,{

	parseTagExpr: function(debug) {

		if (this.trim() == "")
			return "(true)";

		var logicOps = /(!|&&|\|\||\(|\))/g;

		var spaced = this.
 			// because square brackets in templates are no good
			// this means you can use [(With Spaces)] instead of [[With Spaces]]
			replace(/\[\(/g," [[").
			replace(/\)\]/g,"]] "). 
			// space things out so we can use readBracketedList. tricky eh?
			replace(logicOps," $1 ");


		var expr = "";

		var tokens = spaced.readBracketedList(false); // false means not unique. nice one JR!

		tokens.each(function(tok) {

			if (tok.match(logicOps)) {
				expr += tok;
			}
			else if (tok.match(/^parent:/)) {
				// experimental
				var lookForTagInParent = tok.split(":")[1];
				expr += "tiddler.parents().anyHasTag('"+lookForTagInParent+"')";
			}					
			else {
				expr += "tiddler.tags.contains('%0')".format([
						// fix single quote bug. hurrah
						// but still have nasty round bracket bug
						tok.replace(/'/,"\\'")
					]);
			}
		});

		if (debug)
			alert(expr);

		return '('+expr+')';
	}

});

merge(Tiddler.prototype,{

	matchesEvalExpr: function(evalExpr) {
		var tiddler = this;
		return eval(evalExpr);
	},

	matchesTagExpr: function(tagExpr) {
		return this.matchesEvalExpr(tagExpr.parseTagExpr());
	},

	olderThanDays: function(days) {
		return this.modified.getTime() < (new Date()).getTime() - days*1000*60*60*24;
	}

});

//------------------------------------

merge(Tiddler.prototype,{

	render: function(method,renderOptions) {
		var renderMethod = "render_"+method;
		if (this[renderMethod])
			return this["render_"+method](renderOptions);
		else
			return "*** cant render "+renderMethod+" ***";
	},

	renderUtil: function(formatString,formatValues) {
		return formatString.format(formatValues);
	},

	sorter: function(field) {
		var sortMethod = "sort_"+field;
		if (this[sortMethod])
			return this[sortMethod]();
		else
			return this[field];
	},

	sorterUtil: function(otherTiddler,method) {
		var desc = false;

		if (method.substring(0,1) == "-") {
			desc = true;
			method = method.substring(1);
		}

		if (this.sorter(method) > otherTiddler.sorter(method))
			return (desc ? -1 : +1);
		else if (this.sorter(method) < otherTiddler.sorter(method))
			return (desc ? +1 : -1);
		else
			return 0;
	}

});

merge(String.prototype,{
	sorterUtil: function(otherTiddler,method) {

		var t1 = store.getTiddler(this);
		var t2 = store.getTiddler(otherTiddler);

		if (method.substring(0,1) == "-") {
			desc = true;
		}

		if (t1 && t2)
			return t1.sorterUtil(t2,method);
		// this part is a little flakey but I'm aiming to
		// put the None heading last in all cases
		else if (t2)
			return +1;
		else if (t1)
			return -1;
		else {
			// neither exist as tiddlers might as well compare strings
			if (this < otherTiddler)
				return (desc ? +1 : -1);
			else if (this > otherTiddler)
				return (desc ? -1 : +1);
			else
				return 0;
		}
	}
});

//------------------------------------------

merge(Array.prototype,{

	// returns a hash
	groupBy_hash: function(func) {
		var result = {};
		var leftOverGroup = '__NONE__';
		this.each(function(item) {
			var groups = func(item);
			if (groups.length > 0) {
				groups.each(function(group) {
					if (!result[group])
						result[group] = [];
					result[group].push(item);
				});
			}
			else {
				if (!result[leftOverGroup])
					result[leftOverGroup] = [];
				result[leftOverGroup].push(item);
			}
		});
		return result;
	},

	// returns an array of arrays, like Hash#sort in ruby
	groupBy: function(func,itemSort,groupSort) {

		if (!itemSort) itemSort = "title";
		if (!groupSort) groupSort = "-title";

		var result = this.groupBy_hash(func);
		var sortedResult = [];
		for (var g in result)
			sortedResult.push([g,result[g].sort(function(a,b){return a.sorterUtil(b,itemSort);})]);
		return sortedResult.sort(function(a,b){return a[0].sorterUtil(b[0],groupSort);});
	},

	// for convenience since it's mostly what we want
	groupByTag: function(tag,itemSort,groupSort) {
		return this.groupBy(function(t){return t.getByIndex(tag);},itemSort,groupSort);
 	}

});

//------------------------------------------

// for lists of tiddlers
merge(Array.prototype,{
	
	filterByEval: function(evalExpr) {
		return this.select(function(t) {
			return t.matchesEvalExpr(evalExpr);
		});
	},

	filterByTagExpr: function(tagExpr) {
		return this.filterByEval(tagExpr.parseTagExpr());
	},

	filterGroupsByEval: function(evalExpr) {
		// presumes the group name is a tiddler
		return this.select(function(tGroup) {
			var tiddler = store.getTiddler(tGroup[0]);
			return tiddler && tiddler.matchesEvalExpr(evalExpr);
		});
	},

	filterGroupsByTagExpr: function(tagExpr) {
		return this.filterGroupsByEval(tagExpr.parseTagExpr());
	},

	render: function(renderMethod,renderOptions) {
		return this.map(function(tiddler){
			return tiddler.render(renderMethod,renderOptions);
		}).join("\n");
	},

	renderGrouped: function(listRenderMethod,headingRenderMethod,noneHeading,renderOptions,groupCountOnly,nbTags) {
		// do I ever use renderOptions??
		// this lost some elegance when I shoehorned the groupCountOnly part in. todo refactor
		// then lost some more with the nbTags addition...
		// might need some reworking
		var result = "";
		this.each(function(g) {
			var groupName = g[0];
			var groupItems = g[1];

			var showCount = "";
			if (groupCountOnly && groupCountOnly != "")
				showCount = groupItems.length > 0 ? " ("+groupItems.length+")" : "";

			var makeHeading = (groupCountOnly&&groupCountOnly!="") ? "" : "!!";
			var newButtonMarkup = "";

			// this sucks
			if (nbTags && nbTags != '') {
				newButtonMarkup = " "+config.macros.mgtdList.getNewButton(nbTags + " [["+groupName+"]]");
			}

			if (groupName == "__NONE__") {
				result = result + makeHeading + "{{noneHeading{[[("+(noneHeading?noneHeading:"No "+headingRenderMethod)+")]]}}}"+showCount+"\n";
			}
			else {
				var gTiddler = store.getTiddler(groupName);
				if (gTiddler) {
					result = result + makeHeading+gTiddler.render(headingRenderMethod)+showCount+newButtonMarkup+"\n";
				}
				else {
					result = result + makeHeading+"[["+groupName+"]]"+showCount+newButtonMarkup+"\n";
				}
			}
			if (!groupCountOnly || groupCountOnly == "")
				result = result + groupItems.render(listRenderMethod,renderOptions) + "\n";
		});
			
		if (groupCountOnly && groupCountOnly != "")
			result = result.replace(/\n$/,''); // hack. remove trailing linefeed

		return result;
	},

	tiddlerSort: function(sortBy) {
		return this.sort(function(a,b) { return a.sorterUtil(b,sortBy); });
	},

	toTitleList: function() {
		return this.map(function(t){return t.title;});
	}


});

//------------------------------------------


		
config.options.txtTheme = 'MonkeyGTDTheme';

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

config.mGTD.specialTags = [
		"Action",
		"Project",
		"Area",
		//"Realm",
		"Context",
		"View",
        "Tickler",
		"Reference",
		"Contact"
]
config.mGTD.tagsToIndex = [
		"Action",   // needed for action dependencies
		"Project",
		"Area",
		"Realm",
		"Context",
		"ActionStatus",
		"TicklerStatus",
		"ProjectStatus",
		"GTDComponent",
		"Sidebar",
		"Contact",
        "TicklerRepeatType"
];

config.mgtdVersion = "3.0 alpha r9902";

config.macros.mgtdVersion={handler:function(place){wikify(config.mgtdVersion,place);}};

config.toggleTagAlwaysTouchModDate = true; // see ToggleTagPlugin



config.shadowTiddlers.SiteTitle = 'MonkeyGTD';
config.shadowTiddlers.SiteSubtitle = 'a getting things done system powered by tiddlywiki';

config.mGTD.getOptChk = function(option) { return store.fetchTiddler('MgtdSettings').tags.contains(option); }
config.mGTD.getOptTxt = function(fieldName) { return store.fetchTiddler('MgtdSettings').fields[fieldName.toLowerCase()]; }
config.mGTD.setOptTxt = function(fieldName,fieldValue) { store.fetchTiddler('MgtdSettings').fields[fieldName.toLowerCase()] = fieldValue; }

// from tiddlytools.com/#CoreTweaks, thanks Eric
window.coreWikify = wikify;
window.wikify = function(source,output,highlightRegExp,tiddler)
{
	if (source) arguments[0]=source.replace(/\\\\\n/mg,"<br>");
	coreWikify.apply(this,arguments);
}

readOnly = false;
showBackstage = true;

merge(Date.prototype,{
	addDay:   function(n) { this.setDate(  this.getDate()      + n   ); },
	addWeek:  function(n) { this.setDate(  this.getDate()      + n*7 ); },
	addMonth: function(n) { this.setMonth( this.getMonth()     + n   ); },
	addYear:  function(n) { this.setYear(  this.getFullYear()  + n   ); }
});


// it works in view mode, that's why we can't just use edit macro
merge(config.macros, {
	mgtdEditField: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			var fieldName = params[0];
			var useTiddler = tiddler;
			if (params[1])
				useTiddler = store.fetchTiddler(params[1]);
			var curVal = useTiddler.fields[fieldName] || '';
			var editBox = createTiddlyElement(place,'input',null,'editBox');            
			editBox.value = curVal;
			var callback = function(){
				useTiddler.fields[fieldName] = this.value;
				useTiddler.touch();	// see MgtdDateUtils
			}
			editBox.onchange = callback;
		}
	}
});
function wikifiedMessage(message) {
	wikify(message,getMessageDiv());
}

merge(config.macros,{

	help: {

		handler: function (place,macroName,params,wikifier,paramString,tiddler) {
			createTiddlyButton(place,"?","help",function() {
				var useThis = params[0]?params[0]:tiddler.title;
				var help = store.getTiddlerText("MonkeyGTDHelp##"+useThis);
				help = help?help:"//No help for <nowiki>"+useThis+"</nowiki>//";
				var helpContent = "{{help{\n''[[MonkeyGTD Documentation|http://www.tiddlywiki.org/wiki/MonkeyGTD]]''\n" +
									"!<nowiki>" + useThis + "</nowiki>\n" +
									help + "\n\n" +
									"[[More...|http://www.tiddlywiki.org/wiki/MonkeyGTD/"+useThis+"]]" +
									"\n}}}\n" + 
									"";

				// doesn't work at all. I have no idea how to use TW popups apparently ...
				//var popup = Popup.create(place,"div","popupTiddler");
				//wikify(helpContent,popup,null,tiddler);
				//Popup.show();

				// stick with this for now
				clearMessage();
				wikifiedMessage(helpContent);

				return false;
			});
		}
	}

});

config.indexedTags = {

	// will be populated with our tag lists
	tagLists: {},

	// will be populated with our tag indexes
	indexes: {},

	// will be populated with the tags that need indexing
	tagsToIndex: [],

	saveTiddlerHijack: function(title,newTitle,newBody,modifier,modified,tags,fields) {
		var before = store.getTiddler(title);
		var oldTags = before ? [].concat(before.tags) : null;  // concat so we get a dup

		store.suspendNotifications();
		var result = this.saveTiddler_orig_indexedTags(title,newTitle,newBody,modifier,modified,tags,fields);
		var newTags = store.getTiddler(newTitle).tags;

		config.indexedTags.updateTagLists(title,oldTags,newTitle,newTags);
		config.indexedTags.updateIndexes(title,newTitle,newTags);

		store.resumeNotifications();
		store.notify(title,true);

		return result;
	},

	removeTiddlerHijack: function(title) {
		var before = store.getTiddler(title);
		var oldTags = before ? [].concat(before.tags) : null;  // concat so we get a dup

		store.suspendNotifications();
		this.removeTiddler_orig_indexedTags(title);

		config.indexedTags.updateTagLists(title,oldTags);
		config.indexedTags.updateIndexes(title);

		store.resumeNotifications();
		store.notify(title,true);
	},

	setTiddlerTagHijack: function(title,status,tag) {

		clearMessage(); // unrelated to indexedTags but....

		var before = store.getTiddler(title);
		var oldTags = before ? [].concat(before.tags) : null;  // concat so we get a dup

		store.suspendNotifications();
		this.setTiddlerTag_orig_indexedTags(title,status,tag);

		var after = store.getTiddler(title);
		var newTags = after ? after.tags : null;

		config.indexedTags.updateTagLists(title,oldTags,title,newTags);
		config.indexedTags.updateIndexes(title,title,newTags);

		store.resumeNotifications();
		store.notify(title,true);

	},

	updateTagLists: function(title,oldTags,newTitle,newTags) {
		if (oldTags)
			oldTags.each(function(tagName) {
				if (!config.indexedTags.tagLists[tagName])
					config.indexedTags.tagLists[tagName] = []; // fixes TiddlerEncryption/MTS, thanks Patrick Ohly.
				config.indexedTags.tagLists[tagName].remove(title);
			});
		if (newTags)
			newTags.each(function(tagName) {
				if (!config.indexedTags.tagLists[tagName])
					config.indexedTags.tagLists[tagName] = [];
				config.indexedTags.tagLists[tagName].pushUnique(newTitle);
			});
	},

	updateIndexes: function(title,newTitle,newTags) {
		delete config.indexedTags.indexes[title];
		if (newTags) {
			config.indexedTags.indexes[newTitle] = {};
			config.indexedTags.tagsToIndex.each(function(tagToIndex) {
				config.indexedTags.indexes[newTitle][tagToIndex] = [];
				newTags.each(function(tag) {
					if (config.indexedTags.tagLists[tagToIndex] && config.indexedTags.tagLists[tagToIndex].contains(tag)) {
						config.indexedTags.indexes[newTitle][tagToIndex].pushUnique(tag);
					}
				});
			});
		}
	},

	initTagLists: function() {
		store.getTags().map(function(pair) { return pair[0]; }).each(function(t) {
			config.indexedTags.tagLists[t] = store.getTaggedTiddlers(t).map(function(tt) { return tt.title; });
		});
	},

	initIndexes: function() {
		store.forEachTiddler(function(title,tiddler) {
			config.indexedTags.updateIndexes(title,title,tiddler.tags);
		});
	},

	dump: function() {
		alert(this.indexes["Buy petrol for mower"]["Project"]);
		alert(this.indexes["Buy petrol for mower"]["Realm"]);
	},

	tiddlerMethods: {
		getByIndex: function(tag) {
			return config.indexedTags.indexes[this.title][tag];
		},

		hasParent: function(tag) {
			return this.getByIndex(tag).length > 0
		},

		hasNoParent: function(tag) {
			return !this.hasParent(tag);
		},

		hasActiveProject: function() {
			var projs = this.getByIndex("Project");

			if (projs.length == 0)
				// no project but we will say it's active
				// because otherwise it will not show up anywhere
				return true;

			for (var i=0;i<projs.length;i++)
				if (
					(config.indexedTags.indexes[projs[i]]['ProjectStatus'].contains('Active'))
					&&
					!store.fetchTiddler(projs[i]).tags.contains('Complete') // seems stupid
					)
					return true;
			return false;
		},

		hasStarredProject: function() {
			// similar to hasActiveProject
			// thanks to Bernhardt Rainer
			var projs = this.getByIndex("Project");

			if (projs.length == 0)
				return false;

			for (var i=0;i<projs.length;i++)
				if (
					(config.indexedTags.indexes[projs[i]]['ProjectStatus'].contains('Starred'))
					&&
					!store.fetchTiddler(projs[i]).tags.contains('Complete') // seems stupid
					)
					return true;
			return false;
		},

		getAreasForAction: function() {
			// we will go to some trouble to permit actions in multiple areas
			// either explicitly or via their project...
			// also permit multiple projects......
			// explicit:
			var result = [];
			result = result.concat(this.getByIndex("Area"));
			// implicit (via project/s):
			var projs = this.getByIndex("Project");
			for (var i=0;i<projs.length;i++)
				result = result.concat(store.fetchTiddler(projs[i]).getByIndex("Area"));
			return result;
		},

		hasNextAction: function() {
			var children = fastTagged(this.title).filterByTagExpr('Action && !Done && (Next || [(Waiting For)])');
			return children.length > 0;
		},

		hasTickler: function() {
			var children = fastTagged(this.title).filterByTagExpr('Tickler && !Actioned');
			return children.length > 0;
		},

		hasSubProject: function() {
			var children = fastTagged(this.title).filterByTagExpr('Project && !Complete && Active');
			return children.length > 0;
		},

		hasNextActionOrSubProject: function() {
			return (this.hasSubProject() || this.hasNextAction());
		},

		hasNextActionOrSubProjectOrTickler: function() {
			return (this.hasSubProject() || this.hasNextAction() || this.hasTickler());
		}
	},

	globalMethods: {
		fastTagged: function(tag) {
			var list = config.indexedTags.tagLists[tag];
			return (list?list:[]).map(function(t){return store.getTiddler(t);});
		}
	},

	init: function(tagsToIndex) {

		merge(window,this.globalMethods);
		merge(Tiddler.prototype,this.tiddlerMethods);

		this.tagsToIndex = tagsToIndex;
		this.initTagLists();
		this.initIndexes();

		TiddlyWiki.prototype.saveTiddler_orig_indexedTags = TiddlyWiki.prototype.saveTiddler;
		TiddlyWiki.prototype.removeTiddler_orig_indexedTags = TiddlyWiki.prototype.removeTiddler;
		TiddlyWiki.prototype.setTiddlerTag_orig_indexedTags = TiddlyWiki.prototype.setTiddlerTag;
		TiddlyWiki.prototype.saveTiddler = this.saveTiddlerHijack;
		TiddlyWiki.prototype.removeTiddler = this.removeTiddlerHijack;
		TiddlyWiki.prototype.setTiddlerTag = this.setTiddlerTagHijack;

	}
};

config.indexedTags.init(config.mGTD.tagsToIndex);
merge(Tiddler.prototype,{
	// doesn't belong here..
	ticklerIsActive: function() {
		var defaultHourToActivate = 5; // fixme put elsewhere
		var hourToActivate = config.mGTD.getOptTxt('tickleractivatehour') || defaultHourToActivate;
		var nowTime = new Date();
		nowTime.setHours(nowTime.getHours() - hourToActivate); // i'm confused because of UTC versus local. I think mgtd_date is UTC. But has hh:mm:ss is 00:00:00 in local time
		// a tickler without a date is active now. so please add a date to your ticklers. thanks Arkady Grudzinsky
		return (!this.fields.mgtd_date || nowTime.convertToYYYYMMDDHHMM() >= this.fields.mgtd_date );
		
	}

});
merge(config.macros,{

	ticklerAlert: {
		handler: function (place,macroName,params,wikifier,paramString,tiddler) {
			var realmFilter = '';
			if (!config.mGTD.getOptChk('AlertsIgnoreRealm'))
				realmFilter = ' && tiddler.tags.containsAny(config.macros.mgtdList.getActiveRealms())';
			var theList = fastTagged('Tickler').
						filterByTagExpr('!Actioned').
								filterByEval('tiddler.ticklerIsActive()'+realmFilter);
			if (theList.length > 0) {
				var blinker = createTiddlyElement(place,'blink');
				wikify('{{ticklerAlert{[[*ticklers*|Ticklers Requiring Action]]}}}',blinker,null,tiddler);
			}
		}
	},
	mgtdList: {

		getActiveRealms: function() {
			return store.fetchTiddler("MgtdSettings").getByIndex("Realm");
		},

		noActiveRealmMessage: function() {
			// this doesn't work like it ought to?????
			if (this.getActiveRealms().length == 0) {
				//clearMessage();
				displayMessage("Error: No active realms. Please activate at least one realm."); 
			}
		},
		
		getRealm: function(tiddlerTitle) {

			// if we're in a project inherit the realm from the project
			var inTiddler = store.fetchTiddler(tiddlerTitle);
			if (inTiddler && inTiddler.tags.contains('Project')) {
				// get the realm from the project
				return inTiddler.getByIndex('Realm');
			}	

			// otherwise use the active realm 
			var active = config.macros.mgtdList.getActiveRealms();

			if (active.length == 1) {
				return active[0];
			}
			else if (active.length == 0) {
				var fudge = fastTagged('Realm')[0].title;	 // this is a little bit random but they should be seeing the warning by now and fixing it
				return fudge;
			}
			else {
				// if there's more than one active realm use a slice to get the realm priority and choose the highest one
				// TODO, make this prettier
				var toBeat = "zzzzzzz";
				var soFar = active[0];
				for (var i=0;i<active.length;i++) {
					var pri = store.getTiddlerSlice(active[i],"priority");
					if (pri && pri < toBeat) {
						toBeat = pri;
						soFar = active[i];
					}
				}
				return soFar;
			}
		},

		getNewButton: function(tags,extraTags) {
			if (typeof tags != 'string')
				tags = String.encodeTiddlyLinkList(tags);
			return '<<newSavedTiddler label:+ tag:"'+tags+'">>'; // newSavedTiddler wants tags in one param?
		},

		getNewButton: function(tags,extraTags) {
			if (typeof tags != 'string')
				tags = String.encodeTiddlyLinkList(tags);
			return '<<newSavedTiddler prompt:"Enter name for new %1:" tooltip:"Create a new %1" label:"+" tag:"%0">>'.format([
					tags, // newSavedTiddler wants tags in one param?
					tags.readBracketedList()[0] // just show first tag in prompt and tooltip. it's the important one
				]); 
		},


		handler: function (place,macroName,params,wikifier,paramString,tiddler) {

			this.noActiveRealmMessage();

			var pp = paramString.parseParams("tags",null,true);

			// title of the list
			var title = getParam(pp,"title","");

			// local means only look at tiddlers tagged with this tiddler
			// global means look at every tiddler
			var tagMode = getParam(pp,"mode","local");

			// optional. ignored unless mode global. specify for speed gains
			var startTag = getParam(pp,"startTag");

			// eg, "Next && !Done"
			var tagExpr = getParam(pp,"tags","");

			// additional filter. gets eval'ed
			var whereExpr = getParam(pp,"where","");

			// group by another tag
			var groupBy = getParam(pp,"group","");

			// group by count only mode
			var groupCountOnly = getParam(pp,"groupCountOnly","");

			// filter the groups by tag expr
			var gTagExpr = getParam(pp,"gTag","");

			// or eval'ed expression
			var gWhereExpr = getParam(pp,"gWhere","");

			// how to render list items
			var viewType = getParam(pp,"view","plain");

			// how to render headings
			var gViewType = getParam(pp,"gView",groupBy);

			// if there are tiddlers who aren't grouped then give them this title
			// mainly used to label future actions...
			var leftoverTitle = getParam(pp,"leftoverTitle","No "+groupBy);

			// if set to "yes" then we ignore the realm and show everthing
			var ignoreRealm = getParam(pp, "ignoreRealm","");

			// sort items
			var sortBy = getParam(pp,"sort","title");

			// sort groups
			var gSortBy = getParam(pp,"gSort","title");

			// new button
			var newButton = getParam(pp,"newButton",""); // not using 
			var newButtonTags = getParam(pp,"newButtonTags","");

			// don't show empty list
			var dontShowEmpty = getParam(pp,"dontShowEmpty","");

			newButtonTags = newButtonTags.replace(/\[\(/g," [[").replace(/\)\]/g,"]] "); // change [(..)] to [[..]]

			if (!startTag)
				if (tagMode != "global")
					startTag = tiddler.title;

			var listRefreshContainer = createTiddlyElement(place,"div");

			// TODO one big attribute?
			listRefreshContainer.setAttribute("refresh","macro");
			listRefreshContainer.setAttribute("macroName",macroName);

			listRefreshContainer.setAttribute("title",title);
			listRefreshContainer.setAttribute("startTag",startTag);
			listRefreshContainer.setAttribute("tagMode",tagMode);
			listRefreshContainer.setAttribute("tagExpr",tagExpr);
			listRefreshContainer.setAttribute("groupBy",groupBy);
			listRefreshContainer.setAttribute("groupCountOnly",groupCountOnly);
			listRefreshContainer.setAttribute("gTagExpr",gTagExpr);
			listRefreshContainer.setAttribute("whereExpr",whereExpr);
			listRefreshContainer.setAttribute("gWhereExpr",gWhereExpr);
			listRefreshContainer.setAttribute("sortBy",sortBy);
			listRefreshContainer.setAttribute("gSortBy",gSortBy);
			listRefreshContainer.setAttribute("viewType",viewType);
			listRefreshContainer.setAttribute("gViewType",gViewType);
			listRefreshContainer.setAttribute("ignoreRealm",ignoreRealm);
			listRefreshContainer.setAttribute("leftoverTitle",leftoverTitle);
			listRefreshContainer.setAttribute("newButton",newButton);
			listRefreshContainer.setAttribute("newButtonTags",newButtonTags);
			if (tiddler)
				listRefreshContainer.setAttribute("tiddlerTitle",tiddler.title);
			listRefreshContainer.setAttribute("dontShowEmpty",dontShowEmpty);

			this.refresh(listRefreshContainer);
		},

		refresh: function(place) {

			removeChildren(place);

			var title = place.getAttribute("title");
			var startTag = place.getAttribute("startTag");
			var tagMode = place.getAttribute("tagMode");
			var tagExpr = place.getAttribute("tagExpr");
			var groupBy = place.getAttribute("groupBy");
			var groupCountOnly = place.getAttribute("groupCountOnly");
			var gTagExpr = place.getAttribute("gTagExpr");
			var whereExpr = place.getAttribute("whereExpr");
			var gWhereExpr = place.getAttribute("gWhereExpr");
			var sortBy = place.getAttribute("sortBy");
			var gSortBy = place.getAttribute("gSortBy");
			var viewType = place.getAttribute("viewType");
			var gViewType = place.getAttribute("gViewType");
			var ignoreRealm = place.getAttribute("ignoreRealm");
			var leftoverTitle = place.getAttribute("leftoverTitle");
			var newButton = place.getAttribute("newButton");
			var newButtonTags = place.getAttribute("newButtonTags");
			var tiddlerTitle = place.getAttribute("tiddlerTitle");
			var dontShowEmpty = place.getAttribute("dontShowEmpty");

			var wikifyThis = "";

			wikifyThis += "{{mgtdList{\n";

            if (title != "")
			    wikifyThis += "!"+title

			var nbTags;
			if (newButtonTags != '') {
				nbTags = [
						newButtonTags,                                  // the tags specified in the macro params
						'[['+config.macros.mgtdList.getRealm(tiddlerTitle)+']]',    // the realm. always want a realm
						(tagMode=='global'?'':'[['+tiddlerTitle+']]')   // if not global, then the add tiddler we're in, new here style
					].join(' ');


				var nbList = nbTags.readBracketedList();

				var nbExtra = nbTags;

				// also we want an area. another hack. darn you subprojects.. :)
				if (nbList.contains('Project') && !nbList.containsAny(fastTagged('Area').toTitleList())) {
					var foo = store.fetchTiddler(tiddlerTitle).getByIndex('Area');
					if (foo.length > 0) {
						nbExtra += ' [[' + foo[0] + ']]';
					}
				}

				if (nbList.contains('Project') && !nbList.containsAny(fastTagged('ProjectStatus').toTitleList())) {
					// stupid hack for subprojects list in project dashboards
 					// don't want to create a project with no status
					// this is the hack:
					nbExtra += ' Active';
				}

				// same hack thing for actions
				if (nbList.contains('Action') && !nbList.containsAny(fastTagged('ActionStatus').toTitleList())) {
					nbExtra += ' Next';
				}

				wikifyThis += this.getNewButton(nbExtra);
				// but still use nbTags later on in group headings...

			}


            if (title != "" || newButton != "")
			    wikifyThis += "\n";

			wikifyThis += "{{innerList{\n";

			var checkForContent = wikifyThis;

			var theList = [];
			if (startTag && startTag != 'undefined'/* this sucks */) {
				theList = fastTagged(startTag);
			}
			else {
				// why so hard to get an array of all tiddlers?
				store.forEachTiddler(function(t_title,t_tiddler) { theList.push(t_tiddler); });
			}


			if (tagExpr != "") theList = theList.filterByTagExpr(tagExpr);
			if (whereExpr != "") theList = theList.filterByEval(whereExpr);

			if (ignoreRealm != "yes") {
				var activeRealms = config.macros.mgtdList.getActiveRealms();
				theList = theList.select(function(t) {
					var realm = t.getByIndex("Realm");
					return (
						realm.length == 0 ||  // so something with no realm shows up
						realm.containsAny(activeRealms)
					);
				});
			}

            if (groupBy == "day") {
                // experimental. changing a tag doesn't update modified so
                // this isn't as useful
                theList = theList.groupBy(function(t){return [t.modified.formatString('YYYY-0MM-0DD')];});
				wikifyThis += theList.renderGrouped(viewType,gViewType,leftoverTitle);
            }
			else if (groupBy != "") {
				theList = theList.groupByTag(groupBy,sortBy,gSortBy);
				if (gTagExpr != "") theList = theList.filterGroupsByTagExpr(gTagExpr);
				if (gWhereExpr != "") theList = theList.filterGroupsByEval(gWhereExpr);
				wikifyThis += theList.renderGrouped(viewType,gViewType,leftoverTitle,null,groupCountOnly,nbTags);
			}
			else {
				theList = theList.tiddlerSort(sortBy);
				wikifyThis += theList.render(viewType);
			}

			var emptyList = false;
			if (wikifyThis == checkForContent) {
				emptyList = true;
				wikifyThis += "{{none{none}}}";
			}

			wikifyThis += "}}}\n";
			wikifyThis += "}}}\n";

			if (!(dontShowEmpty == "yes" && emptyList))
				wikify(wikifyThis,place,null,tiddler);

			forceReflow(); // fixes rendering issues. (but probably doubles up rendering time??)

		}
	}

});

merge(config.macros,{
	processInbox: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {

			var shortHand = {
				Action: {
					'W': 'Waiting For',
					'N': 'Next',
					'F': 'Future',
					'S': 'Starred'
				},
				Project: {
					'A': 'Active',
					'SM': 'Someday/Maybe',
					'S': 'Starred'
				}
			};

			wikify("Quick add projects and actions (See [[About Quick Add]] for more info):\n",place);
			var pi = createTiddlyElement(place,"textarea",null,"piBox");
			
			wikify("\n",place);

			var a1 = createTiddlyCheckbox(place,"Open created projects",true,null);
			a1.id = 'piShowProjects';

			var a2 = createTiddlyCheckbox(place,"Open created actions",true,null);
			a2.id = 'piShowActions';

			wikify("\n",place);

			var btn = createTiddlyButton(place,"quick add now","create these items",function(e) {
				var lines = pi.value.split("\n");
				var currentProject = "";
				var displayThese = [];

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

					var fields_and_text = lines[i].trim().split(/[|;]{2}/); // anything after || is to become tiddler content
					

					var fields = fields_and_text[0].trim().split(/[|;]/);
					var tiddlerText = fields_and_text[1];


					if (!fields[0] || fields[0].trim() == "") {
						currentProject = "";
					}
					else {

						var title = fields.shift();
						//alert(title);

						// add the realm
						fields.push(config.macros.mgtdList.getRealm());

						if (title.substr(0,1) != '.') {

							//alert("project "+title);

							currentProject = title;

							if (document.getElementById('piShowProjects').checked)
								displayThese.push(title);

							fields.push("Project"); // make it a project
							//fields.push("Active"); // make it active

							if (!fields.containsAny(['SM','A']))
								fields.push('A');

							fields = fields.map(function(f) {
								if (shortHand['Project'][f])
									return shortHand['Project'][f];
								else
									return f;
							});

							if (store.tiddlerExists(title))
								alert("Warning: '"+title+"' already exists, did not create");
							else
								store.saveTiddler(
									title,title,
									tiddlerText ? tiddlerText : "", // content
									config.options.txtUserName,
									new Date(),
									fields, // tags
									null // extra fields
								);
						}
						else {
							//alert("action "+title);

							// default to next actions
							if (!fields.containsAny(['N','F','W']))
								fields.push('N');

							fields = fields.map(function(f) {
								if (shortHand['Action'][f])
									return shortHand['Action'][f];
								else
									return f;
							});

							//alert("action "+title);
							title = title.trim();
							title = title.replace(/^\.+/,'');

							if (document.getElementById('piShowActions').checked)
								displayThese.push(title);

							fields.push("Action"); // make it an action 
							if (currentProject.trim() != "")
								fields.push(currentProject); // make it in this project

							// these should be configurable
							var automagicContexts = {
								'Call':'call',
								'Errand':'buy'
							};
							for (amc in automagicContexts) {
								var checkExists = store.fetchTiddler(amc);
								var startString = automagicContexts[amc];
								if (title.substr(0,startString.length).toLowerCase() == startString && checkExists && checkExists.hasTag('Context')) {
									fields.push(amc);
								}
							}

							if (store.tiddlerExists(title))
								alert("Warning: '"+title+" already exists, did not create");
							else
								store.saveTiddler(
									title,title,
									tiddlerText ? tiddlerText : "", // content
									config.options.txtUserName,
									new Date(),
									fields, // tags
									null // extra fields
								);
						}
					}
				}

				for (var ii=0;ii<displayThese.length;ii++)
					story.displayTiddler("bottom",displayThese[ii]);

				alert("Done creating items");
				return false;
			}); // end of createTiddlyButton

		}
	}
});

!!Options
Show tickler alerts regardless of realm settings.
<<toggleTag AlertsIgnoreRealm MgtdSettings>>

Actions can have multiple contexts. 
<<toggleTag MultipleContexts MgtdSettings>>

Show full project name next to actions in action lists instead of just [P].
<<toggleTag FullProjectInActionLists MgtdSettings>>

Show full contact name next to actions in action lists instead of just [C].
<<toggleTag FullContactInActionLists MgtdSettings>>

Enter the date format for ticklers.
Tickler date format:<<mgtdEditField ticklerdateformat MgtdSettings>>
(see [[Date Formats|http://tiddlywiki.org/wiki/Date_Formats]]) 

Enter the date format for 'new journal'.
Journal date format:<<mgtdEditField newjournaldateformat MgtdSettings>>
(see [[Date Formats|http://tiddlywiki.org/wiki/Date_Formats]]) 

Hour that ticklers should become active on their tickler date. (0 = Midnight, 12 = Midday)
Tickler activate hour:<<mgtdEditField tickleractivatehour MgtdSettings>>

Should we alert when automatically promoting a dependent action from future to next?
<<toggleTag AlertForDependentActions MgtdSettings>>

// requires MgtdIndexedTags for the fastTagged and getByIndex methods
// TODO make these usable without MgtdIndexedTags if it doesn't exist

merge(Tiddler.prototype,{


	addTag: function(tag) {
		store.setTiddlerTag(this.title,true,tag);
	},

	removeTag: function(tag) {
		store.setTiddlerTag(this.title,false,tag);
	},

	setTagFromGroup: function(tagGroup,tag) {
		var tagList = fastTagged(tagGroup);

		// it goes slow if you don't do this
		store.suspendNotifications();

		// remove all the tags in the group
		for (var i=0;i<tagList.length;i++)
			this.removeTag(tagList[i].title);

		// add the one selected
		if (tag)
			this.addTag(tag);

		// touch the modified date so we can sort usefully
		this.modified = new Date();

		// resume notification and notify
		store.resumeNotifications();
		store.notify(this.title,true);
	},

	toggleTag: function(tag) {
		store.setTiddlerTag(this.title,!this.hasTag(tag),tag);
		// touch the modified date
		this.modified = new Date();
	},

	hasTag: function(tag) {
		return this.tags.contains(tag);
	},

	getParent: function(tag) {
		return this.getByIndex(tag);
	},

	// experimental
	getGrandParent: function(parentTag,grandParentTag) {
		// eg tiddler.getGrandParent('Project','Area') ??
		var result = [];
		this.getByIndex(parentTag).each(function(parentTiddler){
			// because can be multiple
			store.fetchTiddler(parentTiddler).getByIndex(grandParentTag).each(function(grandParentTiddler){
				result.push(grandParentTiddler);
			});
		});
		return result;
	},

	// experimental. does this belong elsewhere?
	actionInArea: function(area) {
		//return this.getParent(area).contains(area) || this.getGrandParent('Project','Area').contains(area);
		return this.getGrandParent('Project','Area').contains(area);
	},

//-----------------------------------

	// experimental. try action dependencies

	actionsDependantOnThisAction: function() {
		return fastTagged(this.title).filterByTagExpr("Action && (Future || Next) && !Done");
	},

	autoNextAnyWaitingActions: function() {
		// XXX exactly what each am I using here?
		// because it looks like this gets munged
		// inside the each function. this makes me think
		// i'm not using the each i think i'm using
		// eek.
		var thisTiddler = this;
		this.actionsDependantOnThisAction().each(function(t){
			if (thisTiddler.hasTag('Done')) {
				if (t.actionCanBecomeNext()) {
					// we still have to check because it might have multiple dependencies
					if (!t.hasTag('Next')) {
						if (config.mGTD.getOptChk('AlertForDependentActions')) {
							alert('Setting dependent action "' + t.title + '" to Next');
						}
						t.setTagFromGroup('ActionStatus','Next');
					}
				}
			}
			else {
				// this is because what if we go in reverse, ie untick the done checkbox
				// also why we need Future || Next in actionsDependantOnThisAction
				// don't need to check anything because any one dependency is enough to trigger going back to Future
				if (!t.hasTag('Future')) {
					if (config.mGTD.getOptChk('AlertForDependentActions')) {
						alert('Setting dependent action "' + t.title + '" to Future');
					}
					t.setTagFromGroup('ActionStatus','Future');
				}
			}
		});
	},

	actionGetDependencies: function() {
		// an action with a parent action
		// we will take to mean that the parent action
		// must be done before this action
		// can become a next action
		return this.getParent('Action');
	},

	actionCanBecomeNext: function() {
		var result = true;
		this.actionGetDependencies().each(function(t){
			if (!store.fetchTiddler(t).hasTag('Done')) {
				// an action this action depends on is not done
				result = false;
			}
		});
		return result;
	},

//-----------------------------------

	hasParent: function(tag) {
		return this.getParent(tag).length > 0;
	},

	realmMismatchWithParent: function(tag) {
		var myRealm = this.getParent('Realm')[0];

		if (!myRealm)
			return true; // no realm, should be fixed..

		var myParent = this.getParent(tag)[0];
		if (!myParent)
			return false; // nothing to be mismatched with

		var parentTiddler = store.fetchTiddler(this.getParent(tag)[0]);
		if (!parentTiddler)
			return true; // doubt it would ever happen but...

		parentRealm = parentTiddler.getParent('Realm')[0]; // we assume one realm only...
		if (!parentRealm)
			return true;

		return parentRealm != myRealm;
	}

});

merge(config.macros,{
	
	singleToggleTag: {

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {

			var pp = paramString.parseParams("tag",null,true);
			
			if (!tiddler)
				tiddler = store.getTiddler(getParam(pp,"title"));
			
			var tag = getParam(pp,"tag");
			var t = store.fetchTiddler(tag);

			var title = getParam(pp,"title",tiddler.title);


			var actOnTiddler = store.getTiddler(title);

			var label = store.getTiddlerSlice(t.title,"button");
			var labelOff = store.getTiddlerSlice(t.title,"buttonOff");

			// dreadful hack
			if (tag == "Starred")
				label = config.mGTD.data.unicodeStar;

			var autoClass = "button " + t.title.replace(/[\/ ]/g,'') 

			if (!label) label = t.title;
			if (!labelOff) labelOff = label;


			var curState = actOnTiddler.hasTag(tag);

			var cl = createTiddlyButton(place, curState?label:labelOff, t.title, function(e) {
					actOnTiddler.toggleTag(tag);
					return false;
				},
				autoClass + " " + (curState ? "on" : "off")
				);
		}
		
	},

	groupOfSingleToggleTags: {

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {

			var pp = paramString.parseParams("tag",null,true);

			var useCheckbox = getParam(pp,"useCheckbox","");
			
			if (!tiddler)
				tiddler = store.getTiddler(getParam(pp,"title"));
			
			var tag = getParam(pp,"tag");

			var title = getParam(pp,"title",tiddler.title);
			var refresh = getParam(pp,"refresh"); // stupid bit for pagetemplate hack

			var includeNew = getParam(pp,"includeNew","yes"); // default on for the moment..

			var actOnTiddler = store.getTiddler(title);

			var getValues = fastTagged(tag).sort(function(a,b){
				return a.sorterUtil(b,"orderSlice");
			});

			getValues.each(function(t) {

				var label = store.getTiddlerSlice(t.title,"button");
				var autoClass = "button " + t.title.replace(/[\/ ]/g,'') 

				if (!label)
					label = t.title;

				if (useCheckbox == "yes") {
					// checkbox style toggle tags
					wikify("<<toggleTag [["+t.title+"]] [["+tiddler.title+"]] ->>[["+label+"]]&nbsp;" ,place,null,tiddler);
				}
				else {
					// button style toggle tags
					var cl = createTiddlyButton(place, label, t.title, function(e) {
							actOnTiddler.toggleTag(t.title);
							if (refresh == "page")
								refreshPageTemplate();
							return false;
						},
						autoClass + " " + (actOnTiddler.getByIndex(tag).contains(t.title) ? "on" : "off")
						);
			 	}
			 });

			 if (includeNew) {
			 	// add a button to create...
				createTiddlyButton(place, "+", "New "+tag+"...", function(e) {
						var newItemTitle = config.macros.multiSelectTag.createNewItem(tag);
						if (newItemTitle)
							actOnTiddler.addTag(newItemTitle);
						if (tag == "Realm")
							refreshPageTemplate();
						return false;
					},
					tag == "Realm"?"button off":"button" // the class so it looks right in the top menu
				);
			 }
		}
		
	},

	multiToggleTag: {

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {

			var pp = paramString.parseParams("tag",null,true);
			
			if (!tiddler)
				tiddler = store.getTiddler(getParam(pp,"title"));
			
			var tag = getParam(pp,"tag");

			var refresh = getParam(pp,"refresh"); // stupid bit for pagetemplate hack
			var longVersion = getParam(pp,"longVersion");

			var title = getParam(pp,"title",tiddler.title);
			var actOnTiddler = store.getTiddler(title);

			var getValues = fastTagged(tag).sort(function(a,b){
				return a.sorterUtil(b,"orderSlice");
			});


			getValues.each(function(t) {
				var label = store.getTiddlerSlice(t.title,longVersion?"buttonLong":"button");

				var extraClass = store.getTiddlerSlice(t.title,"buttonClass");
				var autoClass = (extraClass ? extraClass : "") + " button " + t.title.replace(/[\/ ]/g,'') 
				if (!label) label = t.title;
				var cl = createTiddlyButton(place, label, t.title, function(e) {
						actOnTiddler.setTagFromGroup(tag,t.title);
						if (refresh == "page")
							refreshPageTemplate();
						return false;
					},
					autoClass + " " + (actOnTiddler.getByIndex(tag).contains(t.title) ? "on" : "off")
					);
			});

		}
	},

	multiSelectTag: {

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {

			var pp = paramString.parseParams("tag",null,true);
			
			if (!tiddler)
				tiddler = store.getTiddler(getParam(pp,"title"));
			
			var tag = getParam(pp,"tag");
			var refresh = getParam(pp,"refresh"); // stupid bit for pagetemplate hack

			var allowNone = getParam(pp,"allowNone");

			var includeNew = getParam(pp,"includeNew","yes"); // default on for the moment..

			var title = getParam(pp,"title",tiddler.title);
			var actOnTiddler = store.getTiddler(title);

			var selectOptions = [];

			if (allowNone)
				selectOptions.push({name: null, caption:'-'});// TODO this doesn't work right?

			if (includeNew)
				selectOptions.push({name: '__new__', caption:'New '+tag+'...'});

			var getValues = fastTagged(tag).sort(function(a,b){
				return a.sorterUtil(b,"orderSlice");
			});


			// a few automagic filters should make life easier

			var thisRealm = tiddler.getParent('Realm')[0];

			var filterRealm = "";
			var filterComplete = "";

			//the extra || condition below should take care of contexts now. so actually you can have realm specific contexts if you want
			if (thisRealm && tag != "Realm") { // && tag != "Context") {
				// only want to see things in my realm (or things that don't have a realm...)
				filterRealm += "(tiddler.tags.contains('"+thisRealm.replace(/'/g,"\\'")+"') || !tiddler.hasParent('Realm'))";
			}

			if (tag == "Project") {
				// only want to see active projects
				filterComplete += "!tiddler.tags.contains('Complete')";
			}

			// Big thanks to Kralik and whoever wrote this: http://tiddlywiki.org/wiki/MonkeyGTD/Customization_Guide/Waiting_Actions
			if (tag == "Action") {
				// only want to see active actions; actions only show other actions in same project (or no project)
				if (tiddler.hasParent('Project')) {
					// XXX slightly broken for actions with multiple projects. But i can live with it..
					// note: getParent returns an array
					filterComplete += "(!tiddler.tags.contains('Done') && tiddler.tags.contains('"+tiddler.getParent('Project')[0].replace(/'/g,"\\'")+"'))";
				}
				else {
					filterComplete += "(!tiddler.tags.contains('Done') && !tiddler.hasParent('Project'))"; 
				}

			}

			var filterExpr = "true";

			if (filterRealm != "" && filterComplete != "") {
				filterExpr = filterRealm + " && " + filterComplete;
			}
			else if (filterRealm !=  "") {
				filterExpr = filterRealm;
			}
			else if (filterComplete !=  "") {
				filterExpr = filterComplete;
			}
			// ...yuck

			// exclude ourselves (needed now for action dependencies)
			filterExpr = '((' + filterExpr + ') && (tiddler.title !=  "' + tiddler.title.replace(/'/g,"\\'") + '"))';

			var currentVal = tiddler.getParent(tag)[0];
			if (currentVal && currentVal != '') {
				// prevent weirdness if the current value isn't in the list
				// eg an action in a completed project
				filterExpr = "(" + filterExpr + ") || tiddler.title == '" + currentVal.replace(/'/g,"\\'") + "'";

			}
			if (tag == "Project" && tiddler.hasTag('Project')) {
				// special case: don't let a project be a subproject of itself
				filterExpr = "(" + filterExpr + ") && tiddler.title != '" + tiddler.title.replace(/'/g,"\\'") + "'";
			}

			// okay now do the filtering
			getValues = getValues.filterByEval(filterExpr);

			getValues.each(function(t) {
				var useTitle = store.getTiddlerSlice(t.title,"button");
				if (!useTitle) useTitle = t.title;
				if (useTitle.length > 50) useTitle = useTitle.substr(0,50) + "...";
				selectOptions.push({name: t.title, caption:useTitle});
			});

			var dd = createTiddlyDropDown(place, function(e) {
					var selectedItem = selectOptions[this.selectedIndex].name;
					if (selectedItem == '__new__')
						selectedItem = config.macros.multiSelectTag.createNewItem(tag);

					// if selectedItem is null this works to remove any
					actOnTiddler.setTagFromGroup(tag,selectedItem);

					// Once again, big thanks to Kralik and whoever wrote this: http://tiddlywiki.org/wiki/MonkeyGTD/Customization_Guide/Waiting_Actions
					// automatically make dependent actions future
					if (tag == "Action") {
						if (selectedItem == null) {
							actOnTiddler.setTagFromGroup("ActionStatus", "Next");
						}
						else {
							actOnTiddler.setTagFromGroup("ActionStatus", "Future");
						}
					}

					if (refresh == "page")
						refreshPageTemplate();

					return false;
				},
				selectOptions,
				actOnTiddler.getByIndex(tag)[0]
			);

		},

		// want to reuse this...
		createNewItem: function(tag) {
			var selectedItem = prompt("Enter name for new "+tag+":","");
			if (selectedItem) {
				selectedItem = config.macros.newTiddler.getName(selectedItem); // from NewMeansNewPlugin
				var tags = [];
				tags.push(tag); // make it into the thing you want
				tags.push(config.macros.mgtdList.getRealm()); // make sure it's got a realm
				if (tag == "Project")
					tags.push("Active"); // if it's a project then make it active...
				if (tag == "Action")
					tags.push("Next"); // if it's an action then make it next...
				store.saveTiddler(selectedItem,selectedItem,"",config.options.txtUserName,new Date(),tags);
			}
			return selectedItem;
		}


	},

	multiCheckboxTag: {

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {

			var pp = paramString.parseParams("tag",null,true);
			
			if (!tiddler)
				tiddler = store.getTiddler(getParam(pp,"title"));
			
			var tag = getParam(pp,"tag");

			var title = getParam(pp,"title",tiddler.title);
			var actOnTiddler = store.getTiddler(title);

			var getValues = fastTagged(tag).sort(function(a,b){
				return a.sorterUtil(b,"orderSlice");
			});

			var output = "";
			getValues.each(function(t) {
				output += "<<toggleTag [[%0]] [[%1]] [[%0]]>>".format([
					t.title,
					actOnTiddler.title
				]);
			});

			wikify(output,place,null,tiddler);

		}
	},

	// these don't really belong here but never mind..
	convertToFromTickler: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			if (tiddler.tags.contains('Tickler')) {

				createTiddlyButton(place, "make action", "make this tickler into a next action", function(e) {
						store.suspendNotifications();
						tiddler.removeTag("Tickler");                      
						tiddler.addTag("Action");                      
						tiddler.removeTag("Done");                     
						tiddler.setTagFromGroup("ActionStatus","Next"); 
						store.resumeNotifications();
						store.notify(tiddler.title,true);
						return false;
					});

				createTiddlyButton(place, "make project", "make this tickler into an active project", function(e) {
						store.suspendNotifications();
						tiddler.removeTag("Tickler");                      
						tiddler.addTag("Project");                       
						tiddler.removeTag("Complete");                   
						tiddler.setTagFromGroup("ProjectStatus",'Active');
						store.resumeNotifications();
						store.notify(tiddler.title,true);
						return false;
					});
			}
			if (tiddler.tags.containsAny(['Action','Project'])) {
				createTiddlyButton(place, "make tickler", "make this item into a tickler", function(e) {
						store.suspendNotifications();
						if (tiddler.hasTag("Project")) {
							// a little trick. it makes any actions associated with this project disappear from action lists
							// thanks to Jorge A. Ramos M.
							tiddler.setTagFromGroup("ProjectStatus",'Someday/Maybe');
						}
						tiddler.removeTag("Action");
						tiddler.removeTag("Project");
						tiddler.addTag("Tickler");                          
						if (!tiddler.tags.containsAny(['Daily','Weekly','Monthly','Yearly'])) {
							// thanks Kyle Baker
							tiddler.addTag("Once");
						}
						store.resumeNotifications();
						store.notify(tiddler.title,true);
						return false;
					});
			}
		}
	},

	convertActionToSubProj: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			if (tiddler.tags.contains('Action')) {

				createTiddlyButton(place, "make project", "make this action into a project", function(e) {
						store.suspendNotifications();
						tiddler.removeTag("Action");                      
						tiddler.removeTag("Next");                     
						tiddler.removeTag("Future");                     
						tiddler.removeTag("Waiting For");                     
						tiddler.removeTag("Done");                     
						tiddler.addTag("Project");                      
						tiddler.addTag("Active");                      
						store.resumeNotifications();
						store.notify(tiddler.title,true);
						return false;
					});

			}
		}
	},


	convertActionToReference: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			if (tiddler.tags.contains('Action')) {

				createTiddlyButton(place, "make reference", "make this action into a reference item", function(e) {
						store.suspendNotifications();
						tiddler.removeTag("Action");                      
						tiddler.removeTag("Next");                     
						tiddler.removeTag("Future");                     
						tiddler.removeTag("Waiting For");                     
						tiddler.removeTag("Done");                     
						tiddler.addTag("Reference");                      
						store.resumeNotifications();
						store.notify(tiddler.title,true);
						return false;
					});

			}
		}
	},


	linkToParent: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			var label = params[1] ? params[1] : '>>';
			var useTiddler = params[2] ? store.fetchTiddler(params[2]) : tiddler;
			var links = useTiddler.getByIndex(params[0]);
			var output = "";
			for (var i=0;i<links.length;i++)
				output += ( (i==0?'':' ') + "[[%1|%0]]".format([links[i], label == 'title' ? '['+links[i]+']' : label]) );
			if (output != "")
				wikify(output,place,null,useTiddler);
		}
	},

	// doesn't belong here since it's not a tag thing..
	deleteTiddler: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			var tiddlerToDelete = params[0];
			if (store.tiddlerExists(tiddlerToDelete)) {
				createTiddlyButton(place, '\u00d7', 'Delete tiddler '+tiddlerToDelete, function(e) {
					var deleteIt = true;
					if (config.options.chkConfirmDelete)
						deleteIt = confirm(config.commands.deleteTiddler.warning.format([tiddlerToDelete]));
					if (deleteIt) {
						story.closeTiddler(tiddlerToDelete);
						store.removeTiddler(tiddlerToDelete);
					}
					return false;
				},'deleteTiddlerButton');
			}
		}
	},

	// contributed by ByteDoc
	showNotesIcon: {

		imageData: "",

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			var useTiddler = params[0] ? store.fetchTiddler(params[0]) : tiddler;
			if (useTiddler.text != "") {
				var output = (config.browser.isIE ? // presume IE still can't do data urls
					"(n)".format([useTiddler.title]) :
					"{{showNotesIcon{[img[%0|%1]]}}}".format([wikifyPlain(useTiddler.title).replace(/\|/g,''),config.macros.showNotesIcon.imageData])
				);
				wikify(output,place,null,useTiddler);
			}
		}
	}

});

TiddlyWiki.prototype.setTiddlerTag_orig_SequencedActionPlugin_mgtd3 = TiddlyWiki.prototype.setTiddlerTag;
TiddlyWiki.prototype.setTiddlerTag = function(title,status,tag) {
	// Thanks Carsten Thiele
	var returnVal = this.setTiddlerTag_orig_SequencedActionPlugin_mgtd3(title,status,tag);
	var tiddler = this.fetchTiddler(title);
	if (tiddler && tag == 'Done' && tiddler.hasTag('Action')) { // not doing ticklers yet...
		tiddler.autoNextAnyWaitingActions();
	}
	return returnVal;
}


setStylesheet(["",
".button.off {font-weight:bold;border-color:#eee;background:#fff;color:#ccc;margin:0px;font-size:100%}",
".button.on {font-weight:bold;border-color:#444;background:#888;color:#fff;margin:0px;font-size:100%}",
".button.tiny { font-size:75%; }",
// TODO move this css elsewhere
"#realmSelector .button.off {margin:0 0.5em;padding:0 1em;border:2px solid #aaa;background:#eee;color:#333;}", // actually reversed, ie off is "on"
"#realmSelector .button.on {margin:0 0.5em;padding:0 1em;border:2px solid #999;background:#999;color:#ccc;}", // actually reversed, ie off is "on"

// TODO put into styles instead of here?
// actions
".viewer .Next.button.on {border-color:#55c;background:#cfa;color:#4a4;}",
".viewer .WaitingFor.button.on {border-color:#b84;background:#fdb;color:#b84;}",
".viewer .Future.button.on {border-color:#48b;background:#bdf;color:#48b;}",

// projects
".viewer .Active.button.on {border-color:#55c;background:#cfa;color:#4a4;}",
".viewer .SomedayMaybe.button.on {border-color:#48b;background:#bdf;color:#48b;}",

// ticklers
".viewer .Enabled.button.on {border-color:#55c;background:#cfa;color:#4a4;}",
".viewer .Disabled.button.on {border-color:#b84;background:#fdb;color:#b84;}",

".viewer .Starred.button {padding:0;font-size:100%;}",
".viewer .Starred.button.on {border-color:#fff;background:#fff;color:#f80;}",
".viewer .Starred.button.off {border-color:#fff;background:#fff;color:#ddd;}",

""].join("\n"),"tTag");

//}}}




URL: http://monkeygtd.tiddlyspot.com/upgrade.html
// won't be overwritten by updates

 // eg:

//// config.options.txtTheme = 'MonkeyGTDPrint3x5';
//{{{

merge(config.macros, {
	eval: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			wikify(eval(paramString),place,null,tiddler);
		}
	}
});

//}}}

Fix these manually. These have either no realm or a different realm to their parent.
{{cols2{

{{col{

<<mgtdList
	title:'Action/Project mismatch'
	startTag:Action
	view:star
	mode:global
	ignoreRealm:yes
	where:"tiddler.realmMismatchWithParent('Project')"
	group:Project
	gView:bold
	>>

}}}

{{col{

<<mgtdList
	title:'Projects/Area mismatch'
	startTag:Project
	view:star
	mode:global
	ignoreRealm:yes
	where:"tiddler.realmMismatchWithParent('Area')"
	group:Area
	gView:bold
	>>


<<mgtdList
	title:'Subproject/parent project mismatch'
	startTag:Project
	view:star
	mode:global
	ignoreRealm:yes
	where:"tiddler.realmMismatchWithParent('Project')"
	>>


}}}

}}}
/%
This is the contents of the help you get when you click the question mark button
%/

!Project
A [[Project|Projects Dashboard]] is made up of sub-projects, [[Action|Next and Waiting Actions]] items, and [[Reference Items]]. A project should have a defined set of tasks or actions (that may change) and when these tasks are done the project is done. If a project has no defined finish, consider calling it an [[Area]], and then make terminable projects in the area.

!Action
An [[Action|Next and Waiting Actions]] is a single task that can be completed at one point in time. If an action is more complex than this, considering making it a [[subproject|Subprojects]], or storing information in the action notes area. Using the [[CheckboxPlugin| http://www.tiddlytools.com/#CheckboxPlugin]] you can hid sub-actions inside an action.

!Tickler
A [[tickler|Tickler Dashboard]] is an [[Action|Next and Waiting Actions]] with a date attached. For example, if you need to call someone as part of a [[Project|Projects Dashboard]], that should be an action. But if you need to call someone on a specific day, then make it a [[tickler|Tickler Dashboard]] and MonkeyGTD will remind you on the day that you need to call them.

Example: The Health area contains a Dentist project with Actions Schedule Dentist, Go To Dentist and File Reimbursement. The latter two are Waiting while Schedule Dentist is Next. Once you call and schedule it, select the Go To Dentist Action, set it to Next, and then choose Make Tickler and set a date for the day of (or the day before) your appointment.

!View
No help yet for View

!Context
No help yet for Context

!Area
An [[Area]] is similar to a project, but it has no possible completion. Areas contain projects.

Example: The Health area might contain the project ''Run Marathon'', and the ''Household'' area might contain projects like ''Sell House'' and ''Buy House'' and ''Plant Garden'', each of which might have sub-projects.

!Realm
Realms are the top of the MonkeyGTD hierarchy. Realms contain Areas. Areas contain Projects. A Realm is a large-scale division of all the Areas, Projects, and Actions that might be placed into a GTD context.

!Reference
No help yet for Reference



!Action Dashboard
This Dashboard is the place where you can get an overview of your next actions.  

!Action Dashboard by Project
This Dashboard is the place where you can get an overview of your next actions organised by Project. Note that when doing work you shouldn't be really be using this view. You should be focussed on context rather than project.

!Action Dashboard by Context
This Dashboard is the place where you can get an overview of your next actions organised by Context. This might be too cluttered if you have a lot of actions.  If you know you are in a particular context consider just clicking the context to focus on that context.

!Next Actions
No help yet for Next Actions

!Next Actions by Context
No help yet for Next Actions by Context

!Next Actions by Project
No help yet for Next Actions by Project

!Projects Dashboard
No help yet for Projects Dashboard

!Projects Dashboard by Area
No help yet for Projects Dashboard by Area

!Next and Waiting Actions
No help yet for Next and Waiting Actions

!Next and Waiting Actions by Context
No help yet for Next and Waiting Actions by Context

!Next and Waiting Actions by Project
No help yet for Next and Waiting Actions by Project

!Done Actions
No help yet for Done Actions

!Active Projects With No Next Action
No help yet for Active Projects With No Next Action

!Quick Add
No help yet for Quick Add

!About Quick Add
No help yet for About Quick Add

!Tickler Dashboard
No help yet for Tickler Dashboard

!Ticklers Requiring Action
No help yet for Ticklers Requiring Action

!Reference Items
No help yet for Reference Items

!Starred Items
No help yet for Starred Items

|Name|MonkeyGTD Narrow|
|Description|MonkeyGTD Theme for Narrow Screens|
|PageTemplate|MonkeyGTDTheme##PageTemplate|
|StyleSheet|MonkeyGTDNarrow##StyleSheet|
|ViewTemplate|MonkeyGTDTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|

!StyleSheet
/*{{{*/

[[MonkeyGTDTheme##StyleSheet]]

/* give a little less space for menu */
#sidebar { width: 16em; /* instead of 16em */ }
#displayArea { margin-right:15.7em; /* instead of 15.7em */ }
#sidebarTabs .tabContents { width:15em; /* instead of 15em */ }

.txtMGTDMain .tab {
	font-size:80%!important;
}
.txtMGTDMain .tabContents {
	font-size:90%;
}


[[StyleSheet]]

/*}}}*/

|Name|MonkeyGTD Print 3x5|
|Description|MonkeyGTD Theme for Printing 3x5 Cards|
|PageTemplate|MonkeyGTDTheme##PageTemplate|
|StyleSheet|MonkeyGTDPrint3x5##StyleSheet|
|ViewTemplate|MonkeyGTDTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|

!StyleSheet
/*{{{*/

[[MonkeyGTDTheme##StyleSheet]]

[[MonkeyGTDTheme##Printing3x5Styles]]

[[StyleSheet]]

/*}}}*/


|Name|MonkeyGTD|
|Description|MonkeyGTD Theme|
|PageTemplate|MonkeyGTDTheme##PageTemplate|
|StyleSheet|MonkeyGTDTheme##StyleSheet|
|ViewTemplate|MonkeyGTDTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|

!ViewTemplate
<!--{{{-->
<div macro="showWhen tiddler.tags.containsAny(config.mGTD.specialTags)">
	[[MonkeyGTDTheme##ViewTemplateToolbar]]
	<div class='titleContainer viewer'>[[TitleButtonsSelector]]</div>
	<div macro="showWhenTaggedAny Reference View">
		<!--- just make it look like a normal tiddler --->
		<div class='viewer' macro='view text wikified'></div>
	</div>
	<div macro="else">
		<div macro="showWhen tiddler.text != ''">
			<div class='viewer'>Notes:</div>
			<div class='viewer postityellow' macro='view text wikified'></div>
		</div>
	</div>
	<div class='viewer'>[[DashboardSelector]]</div>
</div>
<div macro="hideWhen tiddler.tags.containsAny(config.mGTD.specialTags)">
	<!--- use standard template for non gtd tiddlers --->
	[[MptwTheme##ViewTemplate]]
</div>
<!--}}}-->

!ViewTemplateToolbar
<!--{{{-->
<!-- it's identical to Mptw at present except add Reference tag to new journal and new tiddler. will probably tweak it more later. -->
<div class='toolbar'>
	<span macro="showWhenTagged systemConfig">
		<span macro="toggleTag systemConfigDisable . '[[disable|systemConfigDisable]]'"></span>
	</span>
	<span macro="showWhenTagged systemTheme"><span macro="applyTheme"></span></span>
	<span macro="showWhenTagged systemPalette"><span macro="applyPalette"></span></span>
	<span macro="showWhen tiddler.tags.contains('css') || tiddler.title == 'StyleSheet'"><span macro="refreshAll"></span></span>
	<span style="padding:1em;"></span>
	<span macro='toolbar closeTiddler closeOthers +editTiddler deleteTiddler > fields syncing permalink references jump'></span>
	<span macro='newHere label:"new here" tag:Reference'></span>
	<span macro='newJournalHere {{config.mGTD.getOptTxt("newjournaldateformat")?config.mGTD.getOptTxt("newjournaldateformat"):"DD-mmm-YY 0hh:0mm"}} tag:Reference'></span>
</div>
<!--}}}-->

!Subtitle
<!--{{{-->
<span class='subtitle'>
	Updated
	<span macro='view modified date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>
	(<span macro='message views.wikified.createdPrompt'></span>
	<span macro='view created date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>)
</span>
<!--}}}-->

!PageTemplate
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
	<div style="float:right" id='searchBox' macro="search Search..."></div>
	<div class='header2'>MonkeyGTD <span style="font-size:75%;font-weight:normal;" macro="mgtdVersion"></span></div>
</div>
<div macro='gradient vert [[ColorPalette::PrimaryMid]] [[ColorPalette::PrimaryDark]]'>
	<div style="float:right" id="toggleSideBar"><span macro="toggleSideBar"></span></div>
	<div class='mtoolbar'>
	<div>
	<span class="label">REALM</span><span id='arealmSelector' macro="groupOfSingleToggleTags tag:Realm title:MgtdSettings refresh:page"></span>
	<span id='ticklerAlert' refresh='content' tiddler='TicklerAlert' force="true"></span>
	<span id='newButtons' refresh='content' tiddler='NewButtons'></span>
	</div>
	</div>
</div>
<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
<div id='sidebar'>
	<div id='sidebarOptions'>
		<span macro="saveChanges"></span>
		<span macro="closeAll"></span>
		<span macro="showWhen store.tiddlerExists('TspotSidebar')||store.isShadowTiddler('TspotSidebar')"><span refresh='content' tiddler='TspotSidebar'></span></span>
		<span macro="showWhen store.tiddlerExists('MgtdSidebarExtra')"><span refresh='content' tiddler='MgtdSidebarExtra'></span></span>
	</div>
	<div id='sidebarTabs' refresh='content' force='true' tiddler='MGTDSidebar'></div>
</div>
<div id='displayArea'>
	<div id='messageArea'></div>
	<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->

!SidebarMenus
<!--{{{-->
<!--- not using --->
<div id='twsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('TW')">
	<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>
	<div id='sidebarTabs' refresh='content' force='true' tiddler='SideBarTabs'></div>
</div>
<div id='twsidebar' macro="hideWhen store.fetchTiddler('MgtdSettings').tags.contains('TW')">
	<div id='sidebarOptions'>
		<span macro="showWhen store.tiddlerExists('TspotSidebar')||store.isShadowTiddler('TspotSidebar')"><span refresh='content' tiddler='TspotSidebar'></span></span>
		<span refresh='content' tiddler='CommonMenu'></span>
	</div>
</div>
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Do Work')">
	<div class="menu" refresh='content' tiddler='DoWorkMenu'></div>
</div>
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Review')">
	<div class='menu' refresh='content' tiddler='ReviewMenu'></div>
</div>
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Process Inbox')">
	<div class='menu' refresh='content' tiddler='ProcessInboxMenu'></div>
</div>
<!---
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Collect Items')">
	<div class='menu' refresh='content' tiddler='CollectItemsMenu'></div>
</div>
--->
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Config')">
	<div class='menu' refresh='content' tiddler='ConfigMenu'></div>
</div>
<!--}}}-->

!Printing3x5Styles
/*{{{*/
@media print {

.cols3 .col {width: 100%; float:none;}
.cols2 .col {width: 100%; float:none;}

.titleContainer {text-align:center;}

/* LAYOUT ELEMENTS
========================================================== */
*
{
 margin: 0;
 padding: 0;

}

body {
 background: #fff;
 color: #000;
 font-size: 6.2pt;
 font-family: "Lucida Grande", "Bitstream Vera Sans", Helvetica,
Verdana, Arial, sans-serif;

}

img {
 max-width: 2.5in;
 max-height: 4.5in;

}

.tiddler {
 margin: 0 0 2em 0;
 border-top: 1px solid #000;
 page-break-before: always;

}

.tiddler:first-child {
 page-break-before: avoid;

}

p, blockquote, ul, li, ol, dt, dd, dl, table
{
 margin: 0 0 .3em 0;

}

h1, h2, h3, h4, h5, h6
{
 margin: .2em 0;

}

h1
{
 font-size: 1.5em;

}

h2
{
 font-size: 1.3em;

}

h3
{
 font-size: 1.25em;

}

h4
{
 font-size: 1.15em;

}

h5
{
 font-size: 1.1em;

}

blockquote
{
 margin: .6em;
 padding-left: .6em;
 border-left: 1px solid #ccc;

}

ul
{
 list-style-type: circle;

}

li
{
 margin: .1em 0 .1em 2em;
 line-height: 1.4em;

}

table
{
 border-collapse: collapse;
 font-size: 1em;

}

hr {
 border: none;
 border-top: dotted 1px #777;
 height: 1px;
 color: #777;
 margin: .6em 0;
}

}/* end @media print */

/*}}}*/


!StyleSheet
/*{{{*/

[[MptwTheme##StyleSheet]]



.header2 {
	background:url(http://randomibis.com/images/monkeygtd/logo-trans.gif) no-repeat -15px 2px transparent;
	padding:5px;
	padding-left:80px;
	color:white;
	font-size:1.3em;
	font-weight:bold;
}

#backstageShow { color:[[ColorPalette::PrimaryLight]] ! important; }

/* the png is superior due to alpha transparency. but IE can't do it */
/* html>body .header2 {background-image:url(http://randomibis.com/images/monkeygtd/logo-trans.png)} */
/* try this trick (also firefox only)... */
html>body .header2 {
	background-image:url()
}

.headerShadow, .headerForeground {
	padding:0;
}

.mtoolbar { padding:0.1em; padding-top:0.5em;}
.mtoolbar .button { margin-left:0.5em; padding:0.2em 0.3em; margin:0.2em 0.3em;  }
.mtoolbar .button.off {background-color:[[ColorPalette::TertiaryMid]]!important; color:black; font-weight:normal;border-color:[[ColorPalette::PrimaryDark]];}
.mtoolbar .button.on {background-color:[[ColorPalette::TertiaryLight]]; color:black; border-color:[[ColorPalette::PrimaryDark]];} 

.mtoolbar .button {
	-moz-border-radius-topleft: 0.5em;
	-moz-border-radius-topright: 0.5em;
}

#newButtons { padding-left:3em; }
#newButtons br { display:none; }
#newButtons .button { background-color:transparent; color:white; border-color:transparent; }

.txtMGTDMain .tabContents {
	font-size:120%;
}

.txtMGTDMore .tabContents {
	font-size:90%;
}

.tabContents .sliderButton {
	font-size:120%;
	background-color:[[ColorPalette::TertiaryLight]];
}



.mtoolbar .label { font-size:80%; color:[[ColorPalette::PrimaryLight]]; padding:0.5em;}


#displayArea {
	margin: 1em 15.7em 0em 1em; /* use the freed up space */
}

#sidebar, #sidebarOptions
	width:18em;
}

#sidebarTabs {
	width:100%;
}

#mainMenu { display:none; }

#sidebar .menu a {
	font-size:140%;
}

#sidebar .menu ul {
	padding-left:2em;
	padding-top:0;
	margin-top:0;
}
#sidebar .menu h1,
#sidebar .menu h2
{
	color:[[ColorPalette::PrimaryDark]];
	margin:0;
	padding:0;
	margin-top:0.25em;
}
#sidebar .menu h1 {
	font-size:180%;
}
#sidebar .menu h2 {
	font-size:140%;
	margin-left:0.5em;
}


.viewer table.twocol,
.viewer table.threecol {
	border-style:none ! important;
	border-collapse:no-collapse;
	width:100%;
	padding:0; margin:0;
}

.viewer table.twocol td,
.viewer table.threecol td {
	border-style:none ! important;
	vertical-align:top;
	padding-right:1em;
}

.viewer table.twocol tr,
.viewer table.threecol tr {
	border-style:none ! important;
}

.viewer table.twocol td {
	width:50%;
}
.viewer table.threecol td {
	width:33%;
}


.mgtdList h1 {
	border-bottom:1px solid #aaa;
	color:#444;
	font-size:110%;
	margin:0;
	padding:0;
}

.mgtdList h1 br {
	display:none;
}

.mgtdList h1 .button {
	border-color:transparent;
	font-weight:bold;
	font-size:110%;
}

.mgtdList h1 .button:hover {
	border-color:#999;
}

.mgtdList h2 {
	border-style:none!important;
	font-size:100%;
	margin:0; padding:0;
	margin-top:0.7em;
	margin-left:-0.2em;
	color:#444;
}

.mgtdList h2 .button {
	border-style:none!important;
}

.mgtdList {
	padding:0;
	padding-right:1em;
}

.mgtdList .innerList {
	padding:0.5em 1em 0em 1em;
}

.tabContents .sliderPanel {
	margin-left:2em;
}
.txtMGTDMain .mgtdList .innerList {
	font-size:80%;
	padding-left:0em;
}

.tabContents li {
	margin-left:2em;
}


.mgtdList .plain { padding-left:1em; }

#sidebar .mgtdList .plain { padding-left:0em; }
#sidebar .tabContents .sliderPanel { margin-left:1em; }
#sidebar .sliderPanel .mgtdList .plain { padding-left:0em; }
#sidebar .mgtdList .noneHeading .tiddlyLink { font-weight:normal!important; }

/* TODO why not just make it all of them... */
.mgtdList .action .tiddlyLinkExisting,
.mgtdList .plain .tiddlyLinkExisting,
.mgtdList .tickler .tiddlyLinkExisting,
.mgtdList .project .tiddlyLinkExisting
{
	font-weight: normal ! important;
}

/* TODO why not just make it all of them... */
.mgtdList .action .tiddlyLink,
.mgtdList .plain .tiddlyLink,
.mgtdList .tickler .tiddlyLink,
.mgtdList .project .tiddlyLink
{
	font-weight: normal ! important;
}

.mgtdList .button {
	font-weight: normal;
	margin:1px;
}

body {
	background: [[ColorPalette::TertiaryLight]];
}

.title { font-size:150%; color:black; }

#monkeygtdsidebar h1 {
	font-size:120%; color:green;
}

.none { color:[[ColorPalette::TertiaryMid]]; font-size:90%; font-style:italic; }

.postityellow {
	background-color:#ffa;
	border:2px solid #dd8;
	padding-left:1em;
	padding-bottom:0.5em;
}
.postityellow h1,
.postityellow h2,
.postityellow h3,
.postityellow h4
{
	border-style:none;
}

#sidebar .sliderButton { font-weight:bold; padding-left:0.25em; }
#sidebar .sliderPanel ul { margin-bottom:0px; }
#sidebar .sliderPanel li { font-weight:medium; font-size:90%; }

#sidebar .mgtdList .innerList .tiddlyLink {
	font-size:120%;
}

.innerList h3 {
    font-size:80%;
    margin:0; padding:0;
    
}

#newButtons .sliderPanel {
	background-color:[[ColorPalette::TertiaryMid]];
	margin-top:4px;
	padding:1em;
	border-top:2px solid #444;
	border-bottom:2px solid #444;
}

#newButtons .sliderPanel br {
	display:inline;
}

#newButtons .sliderPanel .button {
	font-weight:bold;
	color:black
	border:1px solid black;
	background-color:#666;
}

.piBox {
	width:95%;
	height:8em;
}

.smaller { font-size: 85%; }

.scroll10 .innerList {
	overflow:auto;
	height:12em;
}

.dateBox {
	/* TODO make prettier */
	font-weight:medium; font-size:120%; margin:0.1em; background-color:#ffd;
	border:1px solid #ccc;
	background-color:#fff;
	text-align:center;
	width:8em;
}
.mgtdList .dateBox { font-weight:medium; font-size:100%; }

#ticklerAlert br { display:none; }

.ticklerAlert { padding-left:3em; }
.ticklerAlert .tiddlyLink { color:white; }

/* give a little more space for menu */
#sidebar { width: 21em; /* instead of 16em */ }
#displayArea { margin-right:20.7em; /* instead of 15.7em */ }
#sidebarTabs .tabContents { width:94%; /*16.5em;  instead of 15em */ } /* this seems silly */

#messageArea .help { width:40em; font-size:90%; }

#searchBox {
	position:absolute;
	top: 2px;
	right: 7em;
	z-index:200;
	/* make room for backstage link? */
}
#searchBox .button {
	display:none;
}

.tabContents .button {
	display:block;
}
.tabContents .li .button {
	display:inline; /* hack to make for quickopentags in tabTags look right... */
}
.tabContents li .button {
	display:inline; /* hack to make for quickopentags in tabTags look right... */
}

.txtMGTDMain .tab {
	font-size:120%;
}

.projLink .tiddlyLinkExisting, .projLink {
	font-weight:normal;
	color:[[ColorPalette::TertiaryDark]];
}

.projLinkFull .tiddlyLinkExisting, .projLinkFull {
	font-weight:normal;
	color:[[ColorPalette::TertiaryDark]];
	font-size:90%;
}

/* ============= new div based columns ================= */
.col {
  float: left;
  vertical-align:top;
}

.cols3, .cols2 {
	overflow: auto; /* contains floats. tnx FND */
}

/* IE not doing these right :( */
/* .cols3>br, .col>br { display:none; } */

/* so try this instead. it's annoying and will mean you have trouble 
with brs in non-mgtdlist content. .normal might help */
.cols2 br, .cols3 br  { display:none; }
.mgtdList br, .normal { display:block!important; }
.col .mgtdList { margin-bottom:1.5em; } /* since we're no longer seeing the brs... */

.cols3 .col {
  width: 33%;
}
.cols2 .col {
  width: 49%; /* 50% makes IE put them under each other */
}
.clear {
  clear: left;
}
/* ============= */

#toggleSideBar {
	margin-top:0.5em;
	margin-right:0.5em;
}
.button.HideSideBarButton {
	color:[[ColorPalette::PrimaryLight]];
	border-style:none;
	font-weight:bold;
	font-size:80%;
	padding:0em 1em;
	background-color:[[ColorPalette::PrimaryMid]];
	-moz-border-radius: 0.5em;
}

/* applicable for any printing. (moved from the 3x5 section) */
@media print {

	.viewer .tiddlyLink,
	.mgtdList .tiddlyLink,
	.tiddlyLink
	  { color:black ! important; }

	#sidebar, .mtoolbar, .header2, #toggleSideBar, #backstageArea,
	#backstageButton, #searchBox, .subtitle, .button
	  {display: none !important;}

	#displayArea {margin: 0;}
	#contentWrapper .chkOptionInput {border:0; width:0.25cm;}
	.titleContainer {border-bottom: 1px dotted #000;}

	.scroll10 .innerList { height:auto; overflow:visible; }

}


.controls {
	margin: auto;
	margin:0; padding:0;
}
.controls tr, .controls td, .controls {
	border-style:none!important;
	border-collapse:no-collapse;
}

.controls {
	clear:right;
	padding:0.5em;
	margin-top:1em;
	padding-bottom:0.5em;
}

.controlstint {
	background-color:#f0f0f0;
	border:1px solid #ccc!important; 
}

.toolbar .button {
	border-style:none!important;
}

.controls .subtitle {
	margin-left:0;
	padding-left:0;
}

.controls .button {
	background-color:#fff;
}

.controls .label {
	color:#888; font-size:90%;
}

.controls .floatleft {
	padding-right:1em;
	float:left;
}

.controls .floatright {
	padding-left:1em;
	float:right;
}


.controls .clearleft { clear:left; }
.controls .clearright { clear:right; }
.controls .clearboth { clear:both; }

.controls .button.on {
	background-color:#555; border-style:none!important;
}

.controlstint .button.Starred.off,
.controlstint .button.Starred.on
{ background-color:#f0f0f0; border-style:none!important;}

.unboldLinks .tiddlyLink {
	font-weight:normal;
}

.smaller select { font-size:90%; }

.buttonsLikeLinks .button {
	border-style:none!important;
	background:transparent;
	color:#008;
}

.buttonsLikeLinks .button:hover {
	text-decoration:underline;
}

.deleteTiddlerButton {
	color: #a66; font-weight:bold; margin-right:0.4em; margin-left:0.1em; 
}

.tiny {
	font-size:80%;  /* lazy */
}

/* make the icon fit in a bit better */
.showNotesIcon img {
	vertical-align:middle;
	margin-right: 1px;
}

/* for user styles */
[[StyleSheet]]

/*}}}*/

order:3
button:month
buttonLong:monthly

Name: MptwBlack
Background: #000
Foreground: #fff
PrimaryPale: #333
PrimaryLight: #555
PrimaryMid: #888
PrimaryDark: #aaa
SecondaryPale: #111
SecondaryLight: #222
SecondaryMid: #555
SecondaryDark: #888
TertiaryPale: #222
TertiaryLight: #666
TertiaryMid: #888
TertiaryDark: #aaa
Error: #300

This is in progress. Help appreciated.


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:|MptwConfigPlugin|
|Description:|Miscellaneous tweaks used by MPTW|
|Version:|1.0 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#MptwConfigPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#MptwConfigPlugin|
!!Note: instead of editing this you should put overrides in MptwUserConfigPlugin
***/
//{{{
var originalReadOnly = readOnly;
var originalShowBackstage = showBackstage;

config.options.chkHttpReadOnly = false; 		// means web visitors can experiment with your site by clicking edit
readOnly = false;								// needed because the above doesn't work any more post 2.1 (??)
showBackstage = true;							// show backstage for same reason

config.options.chkInsertTabs = true;    		// tab inserts a tab when editing a tiddler
config.views.wikified.defaultText = "";			// don't need message when a tiddler doesn't exist
config.views.editor.defaultText = "";			// don't need message when creating a new tiddler 

config.options.chkSaveBackups = true;			// do save backups
config.options.txtBackupFolder = 'twbackup';	// put backups in a backups folder

config.options.chkAutoSave = (window.location.protocol == "file:"); // do autosave if we're in local file

config.mptwVersion = "2.5.2";

config.macros.mptwVersion={handler:function(place){wikify(config.mptwVersion,place);}};

if (config.options.txtTheme == '')
	config.options.txtTheme = 'MptwTheme';

// add to default GettingStarted
config.shadowTiddlers.GettingStarted += "\n\nSee also [[MPTW]].";

// add select theme and palette controls in default OptionsPanel
config.shadowTiddlers.OptionsPanel = config.shadowTiddlers.OptionsPanel.replace(/(\n\-\-\-\-\nAlso see AdvancedOptions)/, "{{select{<<selectTheme>>\n<<selectPalette>>}}}$1");

// these are used by ViewTemplate
config.mptwDateFormat = 'DD/MM/YY';
config.mptwJournalFormat = 'Journal DD/MM/YY';

//}}}
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|MptwRounded|
|Description|Mptw Theme with some rounded corners (Firefox only)|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
|PageTemplate|MptwTheme##PageTemplate|
|StyleSheet|##StyleSheet|

!StyleSheet
/*{{{*/

[[MptwTheme##StyleSheet]]

.tiddler,
.sliderPanel,
.button,
.tiddlyLink,
.tabContents
{ -moz-border-radius: 1em; }

.tab {
	-moz-border-radius-topleft: 0.5em;
	-moz-border-radius-topright: 0.5em;
}
#topMenu {
	-moz-border-radius-bottomleft: 2em;
	-moz-border-radius-bottomright: 2em;
}

/*}}}*/

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|MptwStandard|
|Description|Mptw Theme with the default TiddlyWiki PageLayout and Styles|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
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|MptwTheme|
|Description|Mptw Theme including custom PageLayout|
|PageTemplate|##PageTemplate|
|ViewTemplate|##ViewTemplate|
|EditTemplate|##EditTemplate|
|StyleSheet|##StyleSheet|

http://mptw.tiddlyspot.com/#MptwTheme ($Rev: 1829 $)

!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>
<!-- horizontal MainMenu -->
<div id='topMenu' refresh='content' tiddler='MainMenu'></div>
<!-- original MainMenu menu -->
<!-- <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>
<!--}}}-->

!ViewTemplate
<!--{{{-->
[[MptwTheme##ViewTemplateToolbar]]

<div class="tagglyTagged" macro="tags"></div>

<div class='titleContainer'>
	<span class='title' macro='view title'></span>
	<span macro="miniTag"></span>
</div>

<div class='subtitle'>
	(updated <span macro='view modified date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>
	by <span macro='view modifier link'></span>)
	<!--
	(<span macro='message views.wikified.createdPrompt'></span>
	<span macro='view created date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>)
	-->
</div>

<div macro="showWhen tiddler.tags.containsAny(['css','html','pre','systemConfig']) && !tiddler.text.match('{{'+'{')">
	<div class='viewer'><pre macro='view text'></pre></div>
</div>
<div macro="else">
	<div class='viewer' macro='view text wikified'></div>
</div>

<div class="tagglyTagging" macro="tagglyTagging"></div>

<!--}}}-->

!ViewTemplateToolbar
<!--{{{-->
<div class='toolbar'>
	<span macro="showWhenTagged systemConfig">
		<span macro="toggleTag systemConfigDisable . '[[disable|systemConfigDisable]]'"></span>
	</span>
	<span macro="showWhenTagged systemTheme"><span macro="applyTheme"></span></span>
	<span macro="showWhenTagged systemPalette"><span macro="applyPalette"></span></span>
	<span macro="showWhen tiddler.tags.contains('css') || tiddler.title == 'StyleSheet'"><span macro="refreshAll"></span></span>
	<span style="padding:1em;"></span>
	<span macro='toolbar closeTiddler closeOthers +editTiddler deleteTiddler > fields syncing permalink references jump'></span> <span macro='newHere label:"new here"'></span>
	<span macro='newJournalHere {{config.mptwJournalFormat?config.mptwJournalFormat:"MM/0DD/YY"}}'></span>
</div>
<!--}}}-->

!EditTemplate
<!--{{{-->
<div class="toolbar" macro="toolbar +saveTiddler saveCloseTiddler closeOthers -cancelTiddler cancelCloseTiddler deleteTiddler"></div>
<div class="title" macro="view title"></div>
<div class="editLabel">Title</div><div class="editor" macro="edit title"></div>
<div macro='annotations'></div>
<div class="editLabel">Content</div><div class="editor" macro="edit text"></div>
<div class="editLabel">Tags</div><div class="editor" macro="edit tags"></div>
<div class="editorFooter"><span macro="message views.editor.tagPrompt"></span><span macro="tagChooser"></span></div>
<!--}}}-->

!StyleSheet
/*{{{*/

/* a contrasting background so I can see where one tiddler ends and the other begins */
body {
	background: [[ColorPalette::TertiaryLight]];
}

/* sexy colours and font for the header */
.headerForeground {
	color: [[ColorPalette::PrimaryPale]];
}
.headerShadow, .headerShadow a {
	color: [[ColorPalette::PrimaryMid]];
}

/* separate the top menu parts */
.headerForeground, .headerShadow {
	padding: 1em 1em 0;
}

.headerForeground, .headerShadow {
	font-family: 'Trebuchet MS' sans-serif;
	font-weight:bold;
}
.headerForeground .siteSubtitle {
	color: [[ColorPalette::PrimaryLight]];
}
.headerShadow .siteSubtitle {
	color: [[ColorPalette::PrimaryMid]];
}

/* make shadow go and down right instead of up and left */
.headerShadow {
	left: 1px;
	top: 1px;
}

/* prefer monospace for editing */
.editor textarea, .editor input {
	font-family: 'Consolas' monospace;
	background-color:[[ColorPalette::TertiaryPale]];
}


/* sexy tiddler titles */
.title {
	font-size: 250%;
	color: [[ColorPalette::PrimaryLight]];
	font-family: 'Trebuchet MS' sans-serif;
}

/* more subtle tiddler subtitle */
.subtitle {
	padding:0px;
	margin:0px;
	padding-left:1em;
	font-size: 90%;
	color: [[ColorPalette::TertiaryMid]];
}
.subtitle .tiddlyLink {
	color: [[ColorPalette::TertiaryMid]];
}

/* a little bit of extra whitespace */
.viewer {
	padding-bottom:3px;
}

/* don't want any background color for headings */
h1,h2,h3,h4,h5,h6 {
	background-color: transparent;
	color: [[ColorPalette::Foreground]];
}

/* give tiddlers 3d style border and explicit background */
.tiddler {
	background: [[ColorPalette::Background]];
	border-right: 2px [[ColorPalette::TertiaryMid]] solid;
	border-bottom: 2px [[ColorPalette::TertiaryMid]] solid;
	margin-bottom: 1em;
	padding:1em 2em 2em 1.5em;
}

/* make options slider look nicer */
#sidebarOptions .sliderPanel {
	border:solid 1px [[ColorPalette::PrimaryLight]];
}

/* the borders look wrong with the body background */
#sidebar .button {
	border-style: none;
}

/* this means you can put line breaks in SidebarOptions for readability */
#sidebarOptions br {
	display:none;
}
/* undo the above in OptionsPanel */
#sidebarOptions .sliderPanel br {
	display:inline;
}

/* horizontal main menu stuff */
#displayArea {
	margin: 1em 15.7em 0em 1em; /* use the freed up space */
}
#topMenu br {
	display: none;
}
#topMenu {
	background: [[ColorPalette::PrimaryMid]];
	color:[[ColorPalette::PrimaryPale]];
}
#topMenu {
	padding:2px;
}
#topMenu .button, #topMenu .tiddlyLink, #topMenu a {
	margin-left: 0.5em;
	margin-right: 0.5em;
	padding-left: 3px;
	padding-right: 3px;
	color: [[ColorPalette::PrimaryPale]];
	font-size: 115%;
}
#topMenu .button:hover, #topMenu .tiddlyLink:hover {
	background: [[ColorPalette::PrimaryDark]];
}

/* make 2.2 act like 2.1 with the invisible buttons */
.toolbar {
	visibility:hidden;
}
.selected .toolbar {
	visibility:visible;
}

/* experimental. this is a little borked in IE7 with the button 
 * borders but worth it I think for the extra screen realestate */
.toolbar { float:right; }

/* fix for TaggerPlugin. from sb56637. improved by FND */
.popup li .tagger a {
   display:inline;
}

/* makes theme selector look a little better */
#sidebarOptions .sliderPanel .select .button {
  padding:0.5em;
  display:block;
}
#sidebarOptions .sliderPanel .select br {
	display:none;
}

/* make it print a little cleaner */
@media print {
	#topMenu {
		display: none ! important;
	}
	/* not sure if we need all the importants */
	.tiddler {
		border-style: none ! important;
		margin:0px ! important;
		padding:0px ! important;
		padding-bottom:2em ! important;
	}
	.tagglyTagging .button, .tagglyTagging .hidebutton {
		display: none ! important;
	}
	.headerShadow {
		visibility: hidden ! important;
	}
	.tagglyTagged .quickopentag, .tagged .quickopentag {
		border-style: none ! important;
	}
	.quickopentag a.button, .miniTag {
		display: none ! important;
	}
}

/* get user styles specified in StyleSheet */
[[StyleSheet]]

/*}}}*/

|Name|MptwTrim|
|Description|Mptw Theme with a reduced header to increase useful space|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
|StyleSheet|MptwTheme##StyleSheet|
|PageTemplate|##PageTemplate|

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

<!-- horizontal MainMenu -->
<div id='topMenu' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<span refresh='content' tiddler='SiteTitle' style="padding-left:1em;font-weight:bold;"></span>:
<span refresh='content' tiddler='MainMenu'></span>
</div>
<div id='sidebar'>
	<div id='sidebarOptions'>
		<div refresh='content' tiddler='SideBarOptions'></div>
		<div style="margin-left:0.1em;"
			macro='slider chkTabSliderPanel SideBarTabs {{"tabs \u00bb"}} "Show Timeline, All, Tags, etc"'></div>
	</div>
</div>
<div id='displayArea'>
	<div id='messageArea'></div>
	<div id='tiddlerDisplay'></div>
</div>

/***
|Description:|A place to put your config tweaks so they aren't overwritten when you upgrade MPTW|
See http://www.tiddlywiki.org/wiki/Configuration_Options for other options you can set. In some cases where there are clashes with other plugins it might help to rename this to zzMptwUserConfigPlugin so it gets executed last.
***/
//{{{

// example: set your preferred date format
//config.mptwDateFormat = 'MM/0DD/YY';
//config.mptwJournalFormat = 'Journal MM/0DD/YY';

// example: set the theme you want to start with
//config.options.txtTheme = 'MptwRoundTheme';

// example: switch off autosave, switch on backups and set a backup folder
//config.options.chkSaveBackups = true;
//config.options.chkAutoSave = false;
//config.options.txtBackupFolder = 'backups';

// uncomment to disable 'new means new' functionality for the new journal macro
//config.newMeansNewForJournalsToo = false;

//}}}

Had someone email me, she had just gone in (brand new Intermediate player wanting to register and wanting to have a look around before tomorrow) and created a login and then couldn't get in to the site, she said it just took her back to the same screen where it asked her all the same information. I think it was because she was choosing 'join' and not actually logging in with her login and password. It didn't appear that there was anything waiting for approval, although I'm not sure that I can see that section anymore, so I went in to see if she was 'active' or not. It showed 'waiting' or whatever that choice is, then I went back a couple of minutes ago and it showed as 'active', I'm assuming that maybe you activated her in between. Katelyn Peters is her name. I sent her an email telling her to try entering her login and password and then clicking on 'login', I hope this is the right info.
<<newSavedTiddler title:'new Action' label:'+ action' tag:{{'Action Next [['+config.macros.mgtdList.getRealm()+']]'}}>>
<<newSavedTiddler title:'new Project' label:'+ project' tag:{{'Project Active [['+config.macros.mgtdList.getRealm()+']]'}}>>
/%<<newSavedTiddler title:'new Tickler' label:'+ tickler' tag:{{'Tickler Once [['+config.macros.mgtdList.getRealm()+']]'}}>>
%/<<calendarPopup '+ tickler' 'new Tickler'>>/% <-- experimental %/
<<newSavedTiddler title:'new Reference Item' label:'+ reference' tag:{{'Reference [['+config.macros.mgtdList.getRealm()+']]'}}>>
<slider quick add>
<<processInbox>>
</slider>
/***
|Name:|NewHerePlugin|
|Description:|Creates the new here and new journal macros|
|Version:|3.0 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#NewHerePlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
merge(config.macros, {
	newHere: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			wikify("<<newTiddler "+paramString+" tag:[["+tiddler.title+"]]>>",place,null,tiddler);
		}
	},
	newJournalHere: {
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			wikify("<<newJournal "+paramString+" tag:[["+tiddler.title+"]]>>",place,null,tiddler);
		}
	}
});

//}}}

/***
|Name:|NewMeansNewPlugin|
|Description:|If 'New Tiddler' already exists then create 'New Tiddler (1)' and so on|
|Version:|1.1.1 ($Rev: 2263 $)|
|Date:|$Date: 2007-06-13 04:22:32 +1000 (Wed, 13 Jun 2007) $|
|Source:|http://mptw.tiddlyspot.com/empty.html#NewMeansNewPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Note: I think this should be in the core
***/
//{{{

// change this or set config.newMeansNewForJournalsToo it in MptwUuserConfigPlugin
if (config.newMeansNewForJournalsToo == undefined) config.newMeansNewForJournalsToo = true;

String.prototype.getNextFreeName = function() {
       var numberRegExp = / \(([0-9]+)\)$/;
       var match = numberRegExp.exec(this);
       if (match) {
               var num = parseInt(match[1]) + 1;
               return this.replace(numberRegExp," ("+num+")");
       }
       else {
               return this + " (1)";
       }
}

config.macros.newTiddler.checkForUnsaved = function(newName) {
	var r = false;
	story.forEachTiddler(function(title,element) {
		if (title == newName)
			r = true;
	});
	return r;
}

config.macros.newTiddler.getName = function(newName) {
       while (store.getTiddler(newName) || config.macros.newTiddler.checkForUnsaved(newName))
               newName = newName.getNextFreeName();
       return newName;
}


config.macros.newTiddler.onClickNewTiddler = function()
{
	var title = this.getAttribute("newTitle");
	if(this.getAttribute("isJournal") == "true") {
		title = new Date().formatString(title.trim());
	}

	// ---- these three lines should be the only difference between this and the core onClickNewTiddler
	if (config.newMeansNewForJournalsToo || this.getAttribute("isJournal") != "true")
		title = config.macros.newTiddler.getName(title);

	var params = this.getAttribute("params");
	var tags = params ? params.split("|") : [];
	var focus = this.getAttribute("newFocus");
	var template = this.getAttribute("newTemplate");
	var customFields = this.getAttribute("customFields");
	if(!customFields && !store.isShadowTiddler(title))
		customFields = String.encodeHashMap(config.defaultCustomFields);
	story.displayTiddler(null,title,template,false,null,null);
	var tiddlerElem = story.getTiddler(title);
	if(customFields)
		story.addCustomFields(tiddlerElem,customFields);
	var text = this.getAttribute("newText");
	if(typeof text == "string")
		story.getTiddlerField(title,"text").value = text.format([title]);
	for(var t=0;t<tags.length;t++)
		story.setTiddlerTag(title,tags[t],+1);
	story.focusTiddler(title,focus);
	return false;
};

//}}}

config.macros.newSavedTiddler={};
config.macros.newSavedTiddler.handler = function(place,macroName,params,wikifier,paramString,tiddler) {
	if (readOnly) {
		return false;
	}
	var p = paramString.parseParams("anon",null,true,false,false);
	var label = getParam(p,"label","NewSavedTiddler");
	var tooltip = getParam(p,"tooltip","");
	//
	// if no tooltip specified, try prompt, title, label
	//
	if (!tooltip) {
		var tPrompt = getParam(p,"prompt","");
		var title  = getParam(p,"title","");
		var label  = getParam(p,"label","");
		if (tPrompt) {
			tooltip = tPrompt;
		}
		else if (title) {
			tooltip = 'Create a ' + title;
		}
		else if (label) {
			tooltip = 'Create a ' + label;
		}
		else {
			tooltip = 'Create a new saved tiddler';
		}
	}
	var btn = createTiddlyButton(place,label,tooltip,this.onClick);
	btn.params = paramString;
	return false;
};

config.macros.newSavedTiddler.onClick = function(e) {
	var p = this.params.parseParams("anon",null,true,false,false);
	var titlePrompt = getParam(p,"prompt","");
	//
	// if no titlePrompt for the popup, try using the title or label fields
	// to personalize the prompt
	//
	if (!titlePrompt) {
		var titleT = getParam(p,"title","");
		var labelT = getParam(p,"label","");
		if (titleT) {
			titlePrompt = 'Enter name for ' + titleT + ":";
		}
		else if (labelT) {
			titlePrompt = 'Enter name for ' + labelT + ":";
		}
		else {
			// default prompt
			titlePrompt = 'Enter name for new tiddler:';
		}
	}
	var title = prompt(titlePrompt,"");
	if (title) {
		if (typeof config.macros.newTiddler.getName == "function")  {
			title = config.macros.newTiddler.getName(title); // from NewMeansNewPlugin
		}
		var text = getParam(p,"text","");
		var tags = getParam(p,"tag","");
		var fields = getParam(p,"fields","").decodeHashMap();
		tags = tags.replace(/\[\(/g,'[[');
		tags = tags.replace(/\)\]/g,']]');

                // Oveek: a fix for TiddlyWeb
                // http://groups.google.com/group/TiddlyWikiDev/browse_thread/thread/edff49f9a9e9f47b/e02cb3c4ba88f819?pli=1
                merge(fields, config.defaultCustomFields, true); 

		var tiddler = store.saveTiddler(title,title,text,config.options.txtUserName,new Date(),tags,fields);
		autoSaveChanges(null,[tiddler]);
		story.displayTiddler(this,title);
	}
	return false;
}

order:1
button:n
buttonLong:next
<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
	where:tiddler.hasActiveProject()
	newButtonTags:'Action Next'
>>
<<mgtdList title:'Next Actions by Contact' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
	group:Contact
	gView:bold
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
>>
<<mgtdList title:'Next Actions by Context' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
	group:Context
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
>>
<<mgtdList startTag:Action tags:'Next && !Done' view:Action mode:global
	group:Project
	gView:bold
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
	>>
{{cols2{

{{col{

<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
	>>

}}}

{{col{

<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
	newButtonTags:'Action [(Waiting For)]'
	where:tiddler.hasActiveProject()
	>>

}}}

}}}
{{cols2{

{{col{

<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
	group:Contact
	gView:bold
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
	>>

}}}

{{col{

<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
	group:Contact
	gView:bold
	newButtonTags:'Action [(Waiting For)]'
	where:tiddler.hasActiveProject()
	>>


}}}

}}}
{{cols2{

{{col{

<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
	group:Context
	gView:Context
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
	>>

}}}

{{col{

<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
	group:Contact
	gView:bold
	newButtonTags:'Action [(Waiting For)]'
	where:tiddler.hasActiveProject()
	>>


}}}

}}}
<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
	group:Context
	gView:Context
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
	>>

<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
	group:Context
	gView:Context
	newButtonTags:'Action [(Waiting For)]'
	where:tiddler.hasActiveProject()
	>>
{{cols2{

{{col{

<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:Action mode:global
	group:Project
	gView:bold
	newButtonTags:'Action Next'
	where:tiddler.hasActiveProject()
	>>

}}}

{{col{

<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:Action mode:global
	group:Project
	gView:bold
	where:tiddler.hasActiveProject()
	newButtonTags:'Action [(Waiting For)]'
	>>

}}}

}}}
<<taskTimer OGHAWorkLog>>


http://mail.google.com/mail/#inbox/123d8f6e2d96c95b

*Add Learn To Play program (5-6 year-olds)

Allow members to pay using a credit card online







Add Summer Hockey program registration
Create email tax receipts for Work [[OGHA Online Payment]]


*Clear volunteer roles at new registration? No, because then have nothing for next season unless they go back in.
*Need to be able to specify what roles they're willing to do.
* Add jj_register_volunteer with checked-off roles.
* Add Volunteer link (and list?) to Programs boxes so they specify program-dependent roles.
*Leave the executive/admin ones there in jj_member? Hmmm...

*Make volunteer roles in a table or leave in config.php?
*How to specify them in the jj_program table?
*jj_volunteer for them to specify courses (don't show for now since not updateable?). On [[Family Page]]

*Program Roles:
*Summer Hockey: On Ice, Bench Doors, Trainer, Check-in
*Tryouts: On Ice, Evaluator
*Regular Season: coach, Assistant Coach, Trainer, Manager, Evaluator, Events, Scheduler, Statistician

*Allow for multiple programs
*Move volunteer roles to new tables or register_member
*Get list of volunteers working by program
*Allow assign of volunteer to a team/exec position?
|2009-Aug-06|Change schedule instructions|19:47:38|00:15:00|
|2009-Aug-06|Fix arena maps album|19:59:57|00:12:51|
|2009-Aug-06|Frank re. schedule export|20:50:28|00:02:43|
|2009-Aug-06|Check Outlook schedule import|21:03:45|00:06:05|
|2009-Aug-06|Fix arena maps album|21:12:29|00:03:16|
|2009-Aug-10|Send CrowdWave email|23:41:19|00:29:10|
|2009-Aug-11|Derek re. team mailing lists|14:00:24|00:03:39|
|2009-Aug-11|Add competitive coaches to contacts|22:07:04|00:09:04|
|2009-Aug-13|Fix PayPal error for email|11:16:38|01:00:49|
|2009-Aug-13|Send emails to returned payees|12:32:58|00:27:50|
|2009-Aug-14|Fix cancelled payments & send messages to returned payees|16:13:27|01:29:59|
|2009-Aug-15|Edit home page postings|16:40:56|00:06:13|
|2009-Aug-18|Stephanie re. volunteers email|12:04:19|00:03:27|
/%tasktimer%/

order:1
button:none
buttonLong:one time
So not as many unsubscribes/subscribes sent to mailing list
*admin/plugins/team.php|saveList
Is there any way to show the page numbers at the top and bottom of the pages? I have to continually scroll down to the bottom to switch pages.

Specifically when I'm in the 'members' section and there are a lot of pages, I have to guess which page a certain member is on, scroll down, click on the page number just to find out that I didn't guess the right page, and sometimes I have to do this 3 or 4 times before I get to the right one. Again, I guess it probably comes from being just too darn lazy! The page numbering is built in to the Geeklog code. I'm loathe to fiddle with that code more than I have to since an upgrade would wipe out my changes. The search function would address this problem in any case since it would find the records you need.


jj_member: volunteer & formsOutstanding
jj_volunteer:
jj_volunteer_task:
jj_volunteer_certification??

OGHA: set('Coach', 'Assistant Coach', 'Trainer', 'Manager', 'Evaluator', 'Events', 'Scheduler', 'Statistician')

Leader = Coach = Volunteer??
Catherine Haines: http://mail.google.com/mail/#inbox/12080789ec526e26
/***
|Name:|PrettyDatesPlugin|
|Description:|Provides a new date format ('pppp') that displays times such as '2 days ago'|
|Version:|1.0 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#PrettyDatesPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Notes
* If you want to you can rename this plugin. :) Some suggestions: LastUpdatedPlugin, RelativeDatesPlugin, SmartDatesPlugin, SexyDatesPlugin.
* Inspired by http://ejohn.org/files/pretty.js
***/
//{{{
Date.prototype.prettyDate = function() {
	var diff = (((new Date()).getTime() - this.getTime()) / 1000);
	var day_diff = Math.floor(diff / 86400);

	if (isNaN(day_diff))      return "";
	else if (diff < 0)        return "in the future";
	else if (diff < 60)       return "just now";
	else if (diff < 120)      return "1 minute ago";
	else if (diff < 3600)     return Math.floor(diff/60) + " minutes ago";
	else if (diff < 7200)     return "1 hour ago";
	else if (diff < 86400)    return Math.floor(diff/3600) + " hours ago";
	else if (day_diff == 1)   return "Yesterday";
	else if (day_diff < 7)    return day_diff + " days ago";
	else if (day_diff < 14)   return  "a week ago";
	else if (day_diff < 31)   return Math.ceil(day_diff/7) + " weeks ago";
	else if (day_diff < 62)   return "a month ago";
	else if (day_diff < 365)  return "about " + Math.ceil(day_diff/31) + " months ago";
	else if (day_diff < 730)  return "a year ago";
	else                      return Math.ceil(day_diff/365) + " years ago";
}

Date.prototype.formatString_orig_mptw = Date.prototype.formatString;

Date.prototype.formatString = function(template) {
	return this.formatString_orig_mptw(template).replace(/pppp/,this.prettyDate());
}

// for MPTW. otherwise edit your ViewTemplate as required.
// config.mptwDateFormat = 'pppp (DD/MM/YY)'; 
config.mptwDateFormat = 'pppp'; 

//}}}

[[Quick Add]]
''<<newSavedTiddler title:'new Next Action' label:'new next action' tag:{{'Action Next [['+config.macros.mgtdList.getRealm()+']]'}}>>/%/%
%/<<newSavedTiddler title:'new Waiting Action' label:'new waiting action' tag:{{'Action [(Waiting For)] [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Future Action' label:'new future action' tag:{{'Action Future [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Project' label:'new active project' tag:{{'Project Active [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Someday/Maybe Project' label:'new someday project' tag:{{'Project Someday/Maybe [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
<<newSavedTiddler title:'new Tickler' label:'new tickler' tag:{{'Tickler Once [['+config.macros.mgtdList.getRealm()+']]'}}>>
%/<<calendarPopup 'new tickler' 'new Tickler'>>/% <-- experimental
%/<<newSavedTiddler title:'new Reference Item' label:'new reference' tag:{{'Reference [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/
<<newSavedTiddler title:'new Contact' label:'new contact' tag:{{'Contact [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Context' label:'new context' tag:{{'Context [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Area' label:'new area' tag:{{'Area [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Realm' label:'new realm' tag:{{'Realm [['+config.macros.mgtdList.getRealm()+']]'}}>>''
!!Recent
<<mgtdList mode:global tags:'Project || Action' view:plain sort:-modified >>

{{tiny{
<slider Advanced>
[[modify menu|ProcessInboxMenu]]
[[GTDComponent]]
</slider>
}}}

{{cols2{

{{col{

<<mgtdList title:'Active Projects' startTag:Project tags:'Active && !Complete' view:ProjectArea mode:global
	newButtonTags:'Project Active'
	>>

}}}

{{col{

<<mgtdList title:'Someday/Maybe Projects' startTag:Project tags:'Someday/Maybe && !Complete' view:ProjectArea mode:global
	newButtonTags:'Project Someday/Maybe'
	>>


{{scroll10{
<<mgtdList title:'Completed Projects' startTag:Project tags:'Complete' view:ProjectComplete mode:global>>
}}}

}}}

}}}
{{cols2{

{{col{

<<mgtdList title:'Active Projects' startTag:Project tags:'Active && !Complete' view:Project mode:global
	group:Area
	gView:bold
	newButtonTags:'Project Active'
	>>

}}}

{{col{

<<mgtdList title:'Someday/Maybe Projects' startTag:Project tags:'Someday/Maybe && !Complete' view:Project mode:global
	group:Area
	gView:bold
	newButtonTags:'Project Someday/Maybe'
	>>

{{scroll10{
<<mgtdList title:'Completed Projects' startTag:Project tags:'Complete' view:ProjectComplete mode:global
	group:Area
	gView:bold
	newButtonTags:'Project Active Complete'
	>>

}}}

}}}


}}}

*PayPal details:
**How to get money? Withdraw to bank account (minimum or else a fee)
**Succeeded in payment? IPN
**How do we check that amount was paid? IPN
**Update account (OGHA) automatically? IPN
**Type of reports (Downloadable History Log)

*Keep log of received payments other than in Accounts?
*Can they specify a teammate?
*Send volunteer emails as well?
*Separate out insurance and league fee? ANSWER: Yes
*If they pay the insurance fee then join Work [[OGHA Online Payment]], do they need to pay it for regular season? ANSWER: Yes. We don't track this and it's rare.
<<processInbox>>
/***
|Name:|QuickOpenTagPlugin|
|Description:|Changes tag links to make it easier to open tags as tiddlers|
|Version:|3.0.1 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#QuickOpenTagPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
config.quickOpenTag = {

	dropdownChar: (document.all ? "\u25bc" : "\u25be"), // the little one doesn't work in IE?

	createTagButton: function(place,tag,excludeTiddler) {
		// little hack so we can do this: <<tag PrettyTagName|RealTagName>>
		var splitTag = tag.split("|");
		var pretty = tag;
		if (splitTag.length == 2) {
			tag = splitTag[1];
			pretty = splitTag[0];
		}
		
		var sp = createTiddlyElement(place,"span",null,"quickopentag");
		createTiddlyText(createTiddlyLink(sp,tag,false),pretty);
		
		var theTag = createTiddlyButton(sp,config.quickOpenTag.dropdownChar,
                        config.views.wikified.tag.tooltip.format([tag]),onClickTag);
		theTag.setAttribute("tag",tag);
		if (excludeTiddler)
			theTag.setAttribute("tiddler",excludeTiddler);
    		return(theTag);
	},

	miniTagHandler: function(place,macroName,params,wikifier,paramString,tiddler) {
		var tagged = store.getTaggedTiddlers(tiddler.title);
		if (tagged.length > 0) {
			var theTag = createTiddlyButton(place,config.quickOpenTag.dropdownChar,
                        	config.views.wikified.tag.tooltip.format([tiddler.title]),onClickTag);
			theTag.setAttribute("tag",tiddler.title);
			theTag.className = "miniTag";
		}
	},

	allTagsHandler: function(place,macroName,params) {
		var tags = store.getTags(params[0]);
		var filter = params[1]; // new feature
		var ul = createTiddlyElement(place,"ul");
		if(tags.length == 0)
			createTiddlyElement(ul,"li",null,"listTitle",this.noTags);
		for(var t=0; t<tags.length; t++) {
			var title = tags[t][0];
			if (!filter || (title.match(new RegExp('^'+filter)))) {
				var info = getTiddlyLinkInfo(title);
				var theListItem =createTiddlyElement(ul,"li");
				var theLink = createTiddlyLink(theListItem,tags[t][0],true);
				var theCount = " (" + tags[t][1] + ")";
				theLink.appendChild(document.createTextNode(theCount));
				var theDropDownBtn = createTiddlyButton(theListItem," " +
					config.quickOpenTag.dropdownChar,this.tooltip.format([tags[t][0]]),onClickTag);
				theDropDownBtn.setAttribute("tag",tags[t][0]);
			}
		}
	},

	// todo fix these up a bit
	styles: [
"/*{{{*/",
"/* created by QuickOpenTagPlugin */",
".tagglyTagged .quickopentag, .tagged .quickopentag ",
"	{ margin-right:1.2em; border:1px solid #eee; padding:2px; padding-right:0px; padding-left:1px; }",
".quickopentag .tiddlyLink { padding:2px; padding-left:3px; }",
".quickopentag a.button { padding:1px; padding-left:2px; padding-right:2px;}",
"/* extra specificity to make it work right */",
"#displayArea .viewer .quickopentag a.button, ",
"#displayArea .viewer .quickopentag a.tiddyLink, ",
"#mainMenu .quickopentag a.tiddyLink, ",
"#mainMenu .quickopentag a.tiddyLink ",
"	{ border:0px solid black; }",
"#displayArea .viewer .quickopentag a.button, ",
"#mainMenu .quickopentag a.button ",
"	{ margin-left:0px; padding-left:2px; }",
"#displayArea .viewer .quickopentag a.tiddlyLink, ",
"#mainMenu .quickopentag a.tiddlyLink ",
"	{ margin-right:0px; padding-right:0px; padding-left:0px; margin-left:0px; }",
"a.miniTag {font-size:150%;} ",
"#mainMenu .quickopentag a.button ",
"	/* looks better in right justified main menus */",
"	{ margin-left:0px; padding-left:2px; margin-right:0px; padding-right:0px; }", 
"#topMenu .quickopentag { padding:0px; margin:0px; border:0px; }",
"#topMenu .quickopentag .tiddlyLink { padding-right:1px; margin-right:0px; }",
"#topMenu .quickopentag .button { padding-left:1px; margin-left:0px; border:0px; }",
"/*}}}*/",
		""].join("\n"),

	init: function() {
		// we fully replace these builtins. can't hijack them easily
		window.createTagButton = this.createTagButton;
		config.macros.allTags.handler = this.allTagsHandler;
		config.macros.miniTag = { handler: this.miniTagHandler };
		config.shadowTiddlers["QuickOpenTagStyles"] = this.styles;
		store.addNotification("QuickOpenTagStyles",refreshStyles);
	}
}

config.quickOpenTag.init();

//}}}




*Remove box for second teammate
*Remove database field
*Change code to reflect
*Add note re. The player must also specify you or the request will be considered null and void.
*Clear all requests OR change it to be in register_player (displayed per season)

{{cols2{

{{col{

<<mgtdList title:'Reference Items For Active Projects' tag:Reference startTag:Reference view:plain mode:global
	group:Project
	gView:bold
	newButtonTags:'Reference'
	where:tiddler.hasActiveProject()
	>>

}}}

{{col{

<<mgtdList title:'Other Reference Items' tag:Reference startTag:Reference view:plain mode:global
	group:Project
	gView:bold
	newButtonTags:'Reference'
	where:!tiddler.hasActiveProject()
	>>

}}}

}}}
#Summer Hockey registration
*Payment by cheque only initially
#Online payment (no IPN or encryption)
** We'd have to update Work [[OGHA Online Payment]] accounts manually using info from PayPal account
#Regular season registration
**Online payment but lump sum only
#Deferred payments online
**$100 + 50% (Aug 31) + 50% (Oct 31)
# IPN for online payment
Frank: http://mail.google.com/mail/#inbox/122f1b6b39606b67
Make sure each venue has an address
schedule/index.php|exportTeamScheduleCISV: Check for the address

Didn't work for Outlook
schedule/index.php|exportSchedule: 

/***
|Name:|RenameTagsPlugin|
|Description:|Allows you to easily rename or delete tags across multiple tiddlers|
|Version:|3.0 ($Rev: 5501 $)|
|Date:|$Date: 2008-06-10 23:11:55 +1000 (Tue, 10 Jun 2008) $|
|Source:|http://mptw.tiddlyspot.com/#RenameTagsPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
Rename a tag and you will be prompted to rename it in all its tagged tiddlers.
***/
//{{{
config.renameTags = {

	prompts: {
		rename: "Rename the tag '%0' to '%1' in %2 tidder%3?",
		remove: "Remove the tag '%0' from %1 tidder%2?"
	},

	removeTag: function(tag,tiddlers) {
		store.suspendNotifications();
		for (var i=0;i<tiddlers.length;i++) {
			store.setTiddlerTag(tiddlers[i].title,false,tag);
		}
		store.resumeNotifications();
		store.notifyAll();
	},

	renameTag: function(oldTag,newTag,tiddlers) {
		store.suspendNotifications();
		for (var i=0;i<tiddlers.length;i++) {
			store.setTiddlerTag(tiddlers[i].title,false,oldTag); // remove old
			store.setTiddlerTag(tiddlers[i].title,true,newTag);  // add new
		}
		store.resumeNotifications();
		store.notifyAll();
	},

	storeMethods: {

		saveTiddler_orig_renameTags: TiddlyWiki.prototype.saveTiddler,

		saveTiddler: function(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created) {
			if (title != newTitle) {
				var tagged = this.getTaggedTiddlers(title);
				if (tagged.length > 0) {
					// then we are renaming a tag
					if (confirm(config.renameTags.prompts.rename.format([title,newTitle,tagged.length,tagged.length>1?"s":""])))
						config.renameTags.renameTag(title,newTitle,tagged);

					if (!this.tiddlerExists(title) && newBody == "")
						// dont create unwanted tiddler
						return null;
				}
			}
			return this.saveTiddler_orig_renameTags(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created);
		},

		removeTiddler_orig_renameTags: TiddlyWiki.prototype.removeTiddler,

		removeTiddler: function(title) {
			var tagged = this.getTaggedTiddlers(title);
			if (tagged.length > 0)
				if (confirm(config.renameTags.prompts.remove.format([title,tagged.length,tagged.length>1?"s":""])))
					config.renameTags.removeTag(title,tagged);
			return this.removeTiddler_orig_renameTags(title);
		}

	},

	init: function() {
		merge(TiddlyWiki.prototype,this.storeMethods);
	}
}

config.renameTags.init();

//}}}


ADHD:
*Handwriting: http://www.paperpenalia.com/handwriting.html*
*This is why I doodle: http://www.additudemag.com/adhd/article/print/5575.html
*Handwriting and music: http://www.retrainthebrain.com/index.html
*Autism & ADHD: http://www.retrainthebrain.com/autism.html
*Walk & Talk
*Mozart/Music: http://www.addchoices.com/music.htm
*Palmer Method of Handwriting

Derek

Local High Tech




Ottawa's Hightech Who's Who Directory -
<http://www.canada.com/ottawa/ottawacitizen/specials/whoswho.html>
canada.com

AiT <http://www.ait.ca/>

Ottawa-Carleton High Tech Companies Directory
<http://www.cosmin.com/hightech.html>

Neptec Mission Critical Aerospace and Defense  <http://www.neptec.com/>
Engineering

March Networks --- Careers <http://www.marchnetworks.com/careers/>

QNX Job Opportunities <http://careers.qnx.com/search.html#TPG4>



CommunityZero
<http://ato.smartcapital.ca/jade?strUserName=derek&strPassword=microsoft>


Dipix Mail <https://mail.dipix.com/exchange/logon.asp>

OREB MLS Listing Search
<http://orebweb3.oreb.ca/mlssearch/frm_search.html>

PRO  <http://proline.olgc.ca/home.asp?lang=e> LINE

Yahoo! Sports NHL <http://sports.yahoo.com/nhl>

Yahoo! Sports <http://sports.yahoo.com/nhl>

CottageLINK <http://www.cottagelink.com/>

Cottages for Rent <http://www.cottagesincanada.com/index_e.htm>

AutoTrader.ca
<http://www.trader.ca/search/default.asp?category=1&categoryid=1&CAT=1>

MLS® Online
<http://www.mls.ca/mls/propertysearch.asp?gt=d&L=1&T=RR&pw=chilliwack&map=
1&gc=3043&gc=3041&gc=3044&gc=3039&x=22&y=6>

MLS Listing <http://www.ottawarealestate.org/mlssearch/frm_search.html>






Janet




FlyLady <http://www.flylady.net/index.asp>

Yahoo! GeoCities <http://www.geocities.com/janet_jansen>

Bliss <http://pages.istar.ca/~bci/using.htm>

Yahoo! Briefcase <http://briefcase.yahoo.com/>




Palm




e-Books <http://www.baen.com/library/>

Download.com - Download Euchre here.
<http://download.com.com/3000-2358-10165007.html>






Health




Joy Ikelman's Info on Bipolar Disorder (Manic
<http://www.frii.com/~parrot/bip.html#learn> Depression)

Depression, Bipolar II - Diagnosis
<http://www.psycheducation.org/depression/02_diagnosis.html#Depression-Anx
iety>

Article - Legal Issues - Check it out before you
<http://www3.sympatico.ca/cottagecountry/library/legal-1.htm> concede
squatter's rights

The Efficacy of Psychotherapy <http://www.apa.org/practice/peff.html>

Spiritual Metaphysical Energy Healing Study -
<http://www.innerfocus.org/> Advance Energy Healing School



About.com
<http://homecooking.about.com/gi/dynamic/offsite.htm?site=http%3A%2F%2Fwww
.appetizerrecipe.com%2F> http--www.appetizerrecipe.com-

CHNA <http://www.communityzero.com/chna?user_name=janet.j&password=expo67>


Groups <http://ca.groups.yahoo.com/mygroups>




For Mary




Artistica's Shards <http://www.artistica.com/mall/shards.asp>








Kiah




Ancient  <http://www.crystalinks.com/rome.html> Rome



 _____




Links

Add bookmarks to this folder to see them displayed on the Bookmarks
Toolbar




CASC <http://churchillnews.ca/>

RR#4 <http://www.rr4.ca/>

JEMS <http://jems.ca/>

Thorslund <http://thorslund.ca/>

OGHA <http://www.ottawagirlshockey.com/Main%20Frame.htm>

News <http://ogha.info/>

JADE
<http://ato.smartcapital.ca/jade?strUserName=janet.j&strPassword=expo67>

Yahoo Mail <http://mail.yahoo.com/>

Weather <http://weatheroffice.ec.gc.ca/city/pages/on-118_metric_e.html>

411 <http://findaperson.canada411.ca/>




Banking




EasyWeb <https://easyweb.tdcanadatrust.com/>

PC
<https://www.pcmastercard.pcfinancial.ca/rocen/cardapp/contentPG/sign_in_f
rm.htm?sign_in_select=2>

5181271004146913 09/05 261

Scotia <https://www.scotiaonline.scotiabank.com/online/start.jsp>

Bell <https://belldirect.webapp.bell.ca/BellDirect/index.asp>






Recreation




Ottawa Public
<http://www.library.ottawa.on.ca/english/catalogue/indexcmc.htm> Library

Derek 22950005482336 Janet 22950001801430 Kiah 22950005394721 Aisha
22950007737935

Skating Schedule
<http://www.city.ottawa.on.ca/city_services/recreation/fallwinter/central/
40_2_11_6_en.shtml>

City Facilities
<http://www.city.ottawa.on.ca/city_services/cityfacilities/facilitiesC_en.
shtml>

Ottawa Beaches
<http://www.city.ottawa.on.ca/city_services/yourhealth/environmental/beach
es_en.shtml>

Ottawa Movie Guide - CinemaClock.com <http://www.cinemaclock.com/ott/>

Movie Showtimes
<http://www.foundlocally.com/ottawa/Entertainment/EntMovieTimes.htm>

Dovercourt - Registration <http://www.dovercourt.org/registration.html>

Ottawa Gymnastics Centre
<http://www.ottawagymnasticscentre.ca/index1.html>

Yahoo! Games - Crossword
<http://ca.games.yahoo.com/games/cwsave.html?f=http://download.games.yahoo
.com/games/litsoft/crossword/puzzles/cs020808.puz&t=0&u=MEL.JADED.RAPIDIVE
.UNITE.EXUDEDAMES-ENE.TEPEEADULT.TAPIR.PADSERENE..ENEMY.....MORMONNAILER--
-.WOOL..TROVEPURR.SWISS.EVEN---A-..VEER.EST---T---E-TEN.....-E---..SLATER-
--.---GE.ABODE-----.RALLYSIDE-----.OLLIE.LIS-----.-EALD.SEE>




Vacation




Doran Bay Resort - Links <http://www.doranbayresort.com/links.htm>

Suzy's Cottage...Cedres <http://www.magma.ca/~jstring/cottage/index.html>





Nova Scotia Trip




The Cat Car Ferry Service from Maine to Nova  <http://www.catferry.com/>
Scotia

Bay Ferries Saint John, New Brunswick to Digby,
<http://www.nfl-bay.com/english/bay/> Nova Scotia

Howard Johnson - Where You Feel At Home
<http://www.hojo.com/HowardJohnson/control/home>








Music




Musical Instrument Encyclopedia PIANO
<http://www.lehigh.edu/Zoellner/encyc_piano.html>

The Piano Education Page - Just for Kids
<http://www.unm.edu/~loritaf/pnokids.html#Reference>

Herb Wurtzel's FREE RECORDER MUSIC SCORES
<http://www.angelfire.com/ca2/Herbsrecordermusic/>

The Recorder Player's Page <http://www.saers.com/recorder/dlmusic.php>






Museums




Civilization.ca - Canadian Museum of Civilization
<http://www.civilization.ca/cmc/cinepeng.html> - IMAX Theatre



Euchre <http://ca.games.yahoo.com/games/login?page=eu&cat=advanced>






Kids




Wikipedia <http://en.wikipedia.org/wiki/Main_Page>

Car Travel Activity Book - EnchantedLearning.com
<http://www.enchantedlearning.com/crafts/books/cartravelbook/>

Character Parties
<http://www.birthdaypartyideas.com/html/character_parties_53.html>

Elementary Kids <http://www.geocities.com/elementaryworksheets/faq.htm>

Fun and Games - BONUS.COM® the SuperSite for  <http://www.bonus.com/>
Kids(tm)

Map
<http://images.google.ca/imgres?imgurl=www.gdflow.com/GDFlow/free_test/var
lden.gif&imgrefurl=http://www.gdflow.com/GDFlow/free_test/eng_demo_worldma
p.htm&hl=en&h=311&w=597&start=121&prev=/images%3Fq%3Dfree%2Bmap%2Bworld%2B
gif%26start%3D120%26svnum%3D10%26hl%3Den%26lr%3D%26ie%3DUTF-8%26oe%3DUTF-8
%26sa%3DN>

Freegk -Maps <http://www.freegk.com/legal.php>

Harcourt School Publishers -- The Learning Site
<http://www.harcourtschool.com/>

Car Travel  <http://www.enchantedlearning.com/crafts/books/cartravelbook/>


KinderKorner <http://www.dovercourt.org/kindercorner.html>

Brementown Musicians - Animated Children's Story by
<http://www.brementownmusicians.com/thanks.html> the Brothers' Grimm

Discover Zone
<http://www.mydiscoverzone.com/elementary/stories/study_tips/info.html>

Childrens Books Online
<http://www.childrensbooksonline.org/About_Bunnies/index.htm>




Illnesses




CDC - Fifth Disease
<http://www.cdc.gov/ncidod/diseases/parvovirus/B19.htm> & Parvovirus B19
Infection






Aisha




Smile <http://www.qnet.com/%7Epontius/smile/smilelmp_1%5B1%5D.htm>

Aisha's Website
<http://ato.smartcapital.ca/aisha?strUserName=aishaway&strPassword=jansen9
>

Morocco Map <http://www.map.freegk.com/morocco/morocco.php>

Spider Monkey <http://www.honoluluzoo.org/spider_monkey.htm>

Colombian Black Spider Monkey - Ateles fusciceps
<http://www.scz.org/animals/m/cbspdr.html> robustus

YTV Website <http://www.ytv.com/>

Neopets - Faeries of Neopia <http://www.neopets.com/faeries.phtml>

wild cats jaguars
<http://www.catclub.net/cat_facts/featuredwildcat_details.asp?id=19>






Parties




Bouncing Dolphin Ball - 1-800-PARTYSHop
<http://www.1800partyconsultant.com/_party_favors/BouncingDolphin.cfm?id=8
712>

Creative Parties On Line Secure Catalog
<http://www.party-creations.com/cgi-bin/checkitout/checkitout.cgi?partycre
STORE:CKIE:prod4112+>

Under the Sea <http://www.touchthesea.org/bday_ideas.htm>

Dive In to a Dolphin Party - Family
<http://www.partiesabound.com/article1036.html> & Parenting Children's
Activities

BillyBear4Kids.com
<http://www.billybear4kids.com/holidays/birthday/party/dolphin-nametag.htm
l>

Strawberry Tea Cakes
<http://entertaining.about.com/library/recipes/blstrawberryteacakes.htm>

Strawberryville
<http://www.calstrawberry.com/berryville/yummyfun/strawordysearch.asp>

The Strawberry Facts Page <http://www.jamm.com/strawberry/facts.html>

A Classroom Tea Party <http://www.seedsofknowledge.com/teaparty4.html>








Web Design







Tools




Hex Calculator
<http://www.cs.nyu.edu/courses/fall03/V22.0201-003/hexcalc.html>

XHTML Validation
<http://validator.w3.org/check?uri=http%3A%2F%2Fwww.zeldman.com%2Ffeed%2F>


Gallery Photos on Website
<http://gallery.menalto.com/modules.php?op=modload&name=News&file=index>

SourceForge.net  <http://sourceforge.net/projects/gallery> & Calendar

Money Calculator <http://www.canoe.ca/cgi-bin/calculators/currency/ccalc>







Graphics




eNub the Free Graphics Hub Free Animated
<http://www.enub.com/free_animated_graphics.html> Graphics

Web Graphics <http://graphicssoft.about.com/cs/webguidelines/>

Pics4Learning - Tech4Learning
<http://pics.tech4learning.com/?search=cat&query=Maps>

CIA - The World Factbook <http://www.cia.gov/cia/publications/factbook/>

GIF Editor
<http://www.gifworks.com/cgi-bin/gifworks.pl?img=professor_2_5040.gif&orig
=professor_2_5040.gif&com=effect_replacecolor&view=100&arg=122%2C19%2C254%
2C241%2C203>

Flaming Text (Crackling)
<http://www.flamingtext.com/net-fu/dynamic.cgi?script=plain-logo>






Design




Citations Online <http://www.bedfordstmartins.com/online/cite8.html>

IE 6.0 - QuirksMode  <http://www.quirksmode.org/>

Image Swapping <http://mylibrarian.com/lis/workpad20/workpad20.html>

Web Style Guide <http://www.webstyleguide.com/page/consistent.html>

How to make an Annoying Web Page
<http://www.users.nac.net/falken/annoying/main.html>

Popup Windows
<http://www.htmlcodetutorial.com/linking/linking_famsupp_72.html>

Design Tenets for Web Pages
<http://www.bham.wednet.edu/technology/webtenets.htm>

Upload Files <http://www.dtp-aus.com/howuload.htm>

HTML Editors Evaluation  <http://www.plu.edu/~webmast/editors/claris.html>


Home Page Info <http://www.ioe.ac.uk/brian/downloading.htm>

Jeffrey Zeldman <http://www.zeldman.com/>

cyboray eTECH <http://www.cyboray.com/>

Designing a School Web Site
<http://ottawa.foundlocally.com/Computers/Int-SchoolWebsites.htm>






Technical




HTML <http://www.htmlhelp.com/>

Yahoo! Briefcase - List View <http://briefcase.yahoo.com/janet_jansen>

BigNoseBird.Com's Server Side Include Page (
<http://www.bignosebird.com/ssi.shtml> SSI)

Tripod Canada <http://www.tripod.ca/>

Dave Raggett's Introduction to CSS <http://www.w3.org/MarkUp/Guide/Style>


Services <http://www.photo.net/philg/services.html>

JavaScript and Netscape Frames
<http://www.javaworld.com/jw-04-1996/jw-04-javascript-p2.html>

Cascading Menus - The Web Developer's Journal
<http://www.webdevelopersjournal.com/articles/cascading/menus.html>

Ikonboard 3.0 Services <http://members.ikonboard.com/?bypass=yes>

Hypertext Markup Language - 2.0 - Forms
<http://www.w3.org/MarkUp/html-spec/html-spec_8.html>

http--developer.netscape.com-docs-manuals-communicator-jsref-corea2.htm
<http://developer.netscape.com/docs/manuals/communicator/jsref/corea2.htm#
1013607>

Jumping out of the window - how to get rid of
<http://www.jahns-home.de/rentmei/html/frames.html#the_problem> frames

Netscape4 Issues - 2 Stylesheets <http://www.mako4css.com/csstwo.htm>

Remove Content from Google's Index
<http://www.google.com/remove.html#exclude_pages>

Add your URL to Google <http://www.google.ca/addurl.html>






Geeklog




portalparts.com  <http://www.portalparts.com/quiz/index.php>

Geeklog <http://www.geeklog.net/>

Plugins for Geeklog <http://www.pigstye.net/gplugs/>

Calendar Block
<http://www.geeklog.net/comment.php?type=filemgmt&cid=filemgmt-340>

Kill Title Bar <http://www.geeklog.net/filemgmt/singlefile.php?lid=338>

Gallery Block <http://www.geeklog.net/filemgmt/singlefile.php?lid=334>

Installation Instructions <http://www.geeklog.net/docs/install.html>

Anti-Spam - Fight Back Against Spammers junk
<http://english-3493043618.spamsaver.com/> unsolicited unwanted bulk huge
commercial email spams e-mail! FREE

Squatty.com  <http://www.squatty.com/>

Plone Theme
<http://www.geeklog.net/comment.php?type=filemgmt&cid=filemgmt-239>

Dropdown menus <http://adelga.com/index.php?menu=Websites_>

SourceForge.net Project Filelist
<http://sourceforge.net/project/showfiles.php?group_id=68255>

Sample Site <http://www.microboards.com/>

Iowa Outdoors Theme
<http://www.iowaoutdoors.org/usersettings.php?mode=preferences>

Theme How-To <http://www.geeklog.net/docs/theme.html#changes>

Menu Plugin
<http://prdownloads.sourceforge.net/gplugs/menu_1.6.3_1.3.8.tar.gz?downloa
d>

Geeklog Documentation - Custom Themes
<http://www.doyourdd.us/index.php/CustomThemes>

True Blue
<http://www.geeklog.net/forum/viewtopic.php?forum=6&showtopic=34665&lastpo
st=true>

Multiple Sites <http://www.geeklog.net/faqman/index.php?op=view&t=17>

Multiple Sites...Same Logins
<http://www.geeklog.net/forum/viewtopic.php?forum=3&showtopic=29289>

Geeklog - The Ultimate
<http://www.geeklog.net/filemgmt/singlefile.php?lid=257> Weblog System






Web Hosting




Canaca <http://www.canaca.com/check.html>

Domainsatcost.ca - Canada's Price Leader
<http://www.domainsatcost.ca/index.asp>

Virtual Hosting 2 domains for $11.95 800MB
<http://www.sitevalley.com/virtual_hosting.php?hplan=31>

Canaca $3.95 5GB No MySQL <http://www.canaca.ca/virtual-f.htm>

Arc Hosting $30year 100MB SQL
<http://www.archosting.com/hosting.php?plan=basic>

Funio $75C-100MB Free Domain <http://www.funio.com/EN/Hosting/>

BlueHost.Com <http://www.bluehost.com/>

Ehostpro $4.95 400MB <http://www.ehostpros.com/index.html>

HostingPlex.com $7.45 1GB
<http://www.hostingplex.com/shared/overview.html>

Easy DNS <http://easydns.com/>

Domain Name Service (Bernie) <http://www.easydns.com/>






Reference




HTML Internet free tutorial Preamble <http://www.dtp-aus.com/htmpream.htm>


PHP Manual - A simple tutorial
<http://www.weberdev.com/Manuals/PHP/tutorial.html>

PageTutor.com <http://www.pagetutor.com/tack/toc.html>

Webmonkey Reference HTML Cheatsheet
<http://hotwired.lycos.com/webmonkey/reference/html_cheatsheet/>

JavaScript Documentation
<http://developer.netscape.com/docs/manuals/index.html>

HTML Tags <http://www.utoronto.ca/webdocs/HTMLdocs/NewHTML/htmlindex.html>


ASCII Characters <http://www.webopedia.com/quick_ref/asciicode.asp>




Database




SQL Tutorial <http://www.w3schools.com/sql/default.asp>

Database Selection <http://www.dynamic101.com/database-lesson3-4.html>








WYSIWYG Editors




TinyMCE <http://tinymce.moxiecode.com/>








Hosts




DomainsatCost <http://domainsatcost.ca/master/login.asp>

jems2004 ottawa67




Blog




Blogger <http://www.blogger.com/>

Mike and Kathy's Road Trip 2004 <http://www.eagan.ca/blog/>




Kiah

The coolest girl ever to walk this earth Kiah spends her time playing
sports and playing on the computer.











RR#4




RR#4 <http://www.rr4.ca/>

JADE
<http://ato.smartcapital.ca/jade?strUserName=janet.j&strPassword=expo67>

phpMyAdmin 2.6.0 <http://www.jungle.ca/dba/>






OGHA




OGHA News <http://ogha.info/>

OGHA <http://www.ottawagirlshockey.com/>

cPanel X <http://67.138.240.18:2082/frontend/bluehost/index.html>

phpMyAdmin 2.6.1-pl2 -
<http://67.138.240.18:2082/3rdparty/phpMyAdmin/index.php> 67.138.240.18

Blue Host <http://www.bluehost.com/>

Help <http://helpdesk.bluehost.com/kb/>

SurveyMonkey <http://www.surveymonkey.com/>






CASC




CASC <http://churchillnews.ca/>

ATO
<http://ato.smartcapital.ca/jade?strUserName=janet.j&strPassword=expo67>

Churchill <http://www.ocdsb.edu.on.ca/churweb/>

Canaca <http://www.canaca.ca/virtual.html>

cPanel
<https://66.49.132.150:19638/webhost/services/virtualhosting/siteadmin>

FrontPage
<http://churchillnews.ca/_vti_bin/_vti_adm/fpadmcgi.exe?page=webadmin.htm>





FTP




FTP 110 <ftp://room110:janetf@66.49.161.190/public_html>

FTP 303 <ftp://room303:janeta@66.49.161.190/public_html>

FTP 106 <ftp://room106:sandra@66.49.161.190/public_html>

FTP News <ftp://churchilln:ottawa67@66.49.161.190/mainwebsite_html>






Classrooms




Room 303 <http://room303.churchillnews.ca/>

Room 106 <http://room106.churchillnews.ca/>

Room 110 <http://room110.churchillnews.ca/>






School Sites




Rideau Valley Middle School <http://www.ocdsb.edu.on.ca/RVMSweb/index.htm>


Lake Hills Elementary School
<http://oasis.bellevue.k12.wa.us/lakehills/Classrooms.htm>

Broadview's Home page <http://www.ocdsb.edu.on.ca/BROAweb/index.htm>

FreeWebspace.net - The largest guide to free
<http://www.freewebspace.net/> webhosting.

R.E. Wilson -- Pencils <http://www.ocdsb.edu.on.ca/REWIweb/page4.html>

W. Erskine Johnston Public School -- class
<http://www.ocdsb.edu.on.ca/WEJNweb/> pages

Ottawa Pacers Speed Skating <http://www.magi.com/~pacers/>



phpMyAdmin 2.6.0-pl3 <http://66.49.171.96/MyAdmin/index.php>

Mailout <http://box18.bluehost.com/mailman/admin/news_jems.ca>

school






KCC




Control Panel <http://www.kanatachildrenschorus.ca/cpanel>

SiteHost4U <http://www.sitehost4u.com/contact.php>

http--domainsatcost.ca- <http://domainsatcost.ca/>

FastSubmit - Submit your website to search engines
<http://www.evrsoft.com/fastsubmit/> for FREE!




Websites




BC Boys Choir - Annual Plant Sale
<http://www.bcboyschoir.org/plant_sale.html>

Southern Illinois Children's Choir BAD
<http://www.s-i-c-c.org/Introduction.html>

Pro Coro Canada - BAD <http://www.procoro.ab.ca/record.html>

Welcome to the Capital City Chorus, Singing
<http://www.capitalcitychorus.org/> Barbershop Harmony in Ottawa for Over
45 Years!

http--oryc.on.ca BAD <http://oryc.on.ca/>

Blackburn Chorus <http://www.blackburnchorus.ca/>

Atlantic Voices BAD <http://www.magma.ca/~kcurren/nfchoir.htm>



KCC <http://kanatachildrenschorus.ca/>






Sympatico




FTP <ftp://b1dzaf62@www3.sympatico.ca/>

Sympatico <http://www3.sympatico.ca/janet.jansen/>

GetMail <https://service1.sympatico.ca/login/guestlogin.cfm?>






NCF




NCF Login <http://start.ncf.ca/>

NCF <http://web.ncf.ca/fa795>
**register/index.php|editMember: $currentRole = jjGetFamilyRole($memberID);
[[Projects Dashboard]]
[[Projects Dashboard by Area]]
[[Action Dashboard by Project]]
[[Active Projects With No Next Action]]
[[Someday Projects With No Tickler]]
[[Completed Projects]]
[[Done Actions]]
[[SomedayMaybe and Future]]
[[Delegated Tasks Dashboard]]
[[Cleanup]]
[[Mismatched Realms]]
[[Subprojects]]

<slider+ Areas>
<<mgtdList startTag:Project tags:'Active && !Complete' groupCountOnly:yes group:Area gView:plain>>
</slider>
<slider All areas>
<<mgtdList startTag:Area>>
</slider>

{{tiny{
<slider Advanced>
[[modify menu|ReviewMenu]]
[[GTDComponent]]
</slider>
}}}

INSERT INTO gl_jj_schedule (date, time, teamID1, activityID, venueID, notes, house, publish) VALUES
('2009-09-16', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-09-23', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-09-30', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-10-07', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-10-14', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-10-21', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-10-28', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-11-04', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-11-11', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-11-18', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-11-25', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-12-02', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-12-09', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1),
('2009-12-16', '19:30:00', 19, 21, 82, '<a href="http://maps.google.com/maps?f=q&source=s_q&hl=en&geocode=&q=2525+Lancaster+Road,+ottawa&ie=UTF8&z=16&iwloc=A">OAC</a>', 0, 1);
INSERT INTO gl_jj_schedule (date, time, teamID1, teamID4, activityID, venueID, notes, house, publish, isOurs) VALUES
('2009-09-25', '13:15:00', 36, 730, 82, 6, '<a href="">Arena</a> @ Oshawa Lady Generals', 0, 1, 0),
('2009-09-25', '21:15:00', 36, 730, 82, 6, '<a href="">Arena</a> @ Haldimand River Cats', 0, 1, 0),
('2009-09-26', '13:15:00', 36, 730, 82, 6, '<a href="">Arena</a> vs. West Northumberland Wild', 0, 1, 1),
('2009-09-26', '18:30:00', 36, 730, 82, 6, '<a href="">Arena</a> if 1st or 4th; <a href="">Arena</a> @ 7:45pm if 2nd or 3rd', 0, 1, 1),
('2009-09-27', '11:00:00', 36, 730, 82, 7, '<a href="">Arena</a> or <a href="">Arena</a> @ 11:15am', 0, 1, 1),
('2009-09-27', '14:30:00', 36, 730, 82, 8, '<a href="">Arena</a>', 0, 1, 1);
DELETE FROM `gl_jj_register_family` WHERE registerID > 2;
DELETE FROM `gl_jj_register_player` WHERE registerID > 2;

/***
|Name:|SaveCloseTiddlerPlugin|
|Description:|Provides two extra toolbar commands, saveCloseTiddler and cancelCloseTiddler|
|Version:|3.0 ($Rev: 5502 $)|
|Date:|$Date: 2008-06-10 23:31:39 +1000 (Tue, 10 Jun 2008) $|
|Source:|http://mptw.tiddlyspot.com/#SaveCloseTiddlerPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
To use these you must add them to the tool bar in your EditTemplate
***/
//{{{
merge(config.commands,{

	saveCloseTiddler: {
		text: 'done/close',
		tooltip: 'Save changes to this tiddler and close it',
		handler: function(ev,src,title) {
			var closeTitle = title;
			var newTitle = story.saveTiddler(title,ev.shiftKey);
			if (newTitle)
				closeTitle = newTitle;
			return config.commands.closeTiddler.handler(ev,src,closeTitle);
		}
	},

	cancelCloseTiddler: {
		text: 'cancel/close',
		tooltip: 'Undo changes to this tiddler and close it',
		handler: function(ev,src,title) {
			// the same as closeTiddler now actually
			return config.commands.closeTiddler.handler(ev,src,title);
		}
	}

});

//}}}

Remember that you can use the Search box to locate player accounts. For example, to find Aisha, search for *Aisha*. Include the asterisks because it is searching text fields. You can also change the number of records you view.
/***
|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(); });
}};

//}}}

*Rewrite getMailingList.php to getAllEmails.php => Amalgamate 2008 emails (& Summer Hockey & alumni?)
**Go for id >= specified registerID
**SELECT DISTINCT memberID
**Include players as well as guardians
**Add break after 100 emails
*Remove Stephanie & Mark & families
*Send [[CrowdWave email|http://mail.google.com/mail/#sent/123027608597b9cb]]
*Figure out email addresses: no way of knowing which ones didn't go, I guess. Ask Derek if he received it. Just send again, without Stephanie
ogha.info/register/port/requestPayment.php?id=8
Set &enabled=true
update gl_jj_payment set depositDate='2009-09-15' where chequeCode like 'aug%' and registerID=8
2008-07-08 22:07:00
Janet, here goes the first round of my registration limits.
Is it possible to change this as we have registrations come in? For example, right now we don't even have enough novices to make two teams, so the limit there will be 32, but once we hit the 42 mark (10 on the waiting list), then we could go ahead with 3 teams so the limit would then be 48, can this be changed midway through? My guess is that we'll eventually have enough players to go with the 3 teams, but my fear is that if we set the limit as 48, and we get 34 players, they will be notified that they are 'registered' and then we'll end up having to decline two players because the 3rd team didn't fly. I'd rather put them on a waiting list and then make an extra team and accept them. So here goes:
Novice - limit of 32 (if the numbers rise to 42, we will make this 48)
Atom - limit of 46 (if the numbers rise to 58, we will make this 62)*
*If the Atom Competitive team takes more than 14 players, increase the overall maximum by that #
Peewee - limit of 60 (if the numbers rise to 71, we will make this 77)**
**If Peewee Competitive teams take more than 14 & 15, increase the overall maximum by that #
Bantam - limit of 77***
***If Bantam Competitive teams take more than 14 & 15, increase the overall maximum by that #
Midget - limit of 74 (if the numbers rise to 87, we will make this 92)****
****If Midget Competitive teams take more than 14, 15 & 15, increase the overall maximum by that #
Intermediate - limit of 16******
*****If Intermediate Competitive team takes any of the 16 registered players, increase the overall maximum by that #
NB - this is going to be the HOUSE LEAGUE team, I am not counting the competitive team, because they traditionally only pay a tryout fee and don't actually 'register' with the OGHA until they make the team, so there will be another 17 or 18 players to register at this age level.
Can you please explain to me how the emails work. Once you've set the limits, are emails automatically generated to players who are bumped from the waiting list to 'registered', if so, do the players remaining on the waiting list get emails too?
As per my phone message tonight, is there anyway to count goalies separately?
Yes, once it's working, we can update the registration limits on the Seasons edit page as we go.
The emails will go to people who have been accepted from the waiting list. Do you want to send me generic text for that message? I have the one from last year, but it included info about first practices etc. Is it true that their deposit cheque is cashed once they're off the waiting list?
People who are still on the waiting list don't get an email (could be confusing for them). They can always check their position on the waiting list by logging in. (Though right now, the bug with people being auto-registered after the deadline is linked to the system showing Waiting List #0 for new registrants once I reset their status to waiting...this is the highest on my to-fix list.)
There is no facility for wait listing goalies separately. That would require some work. I'm assuming it would only apply to certain levels, since Novice and Atom (even Peewee?) players might indicate goalie but would play other positions. Do you also try to balance forwards and defence?
For now, we could add a position preference filter to the Registration admin page. That way you could sort by level and position to see the numbers. The question is whether this would negate the idea of auto-emailing people from the waiting list.
A new approach would be to have a checkbox beside wait listed players' names on the Registration admin page. Then you could sort by level and registration date, check off enough players to get to your desired limit (excluding goalies if you already have too many), then click an button that would send the notification and update the players' status to Registered.
Since this last idea would be a change from setting the limits, it would be some work. However, since I'm currently trying to get the other way working, this isn't a bad time to switch directions.
#Set up Welcome and Goodbye messages
#Clear mailing list ((http://www.ogha.info/register/port/getMailingList.php?id=4&team=; paste to Mass Removal)
#Get team list (http://www.ogha.info/register/port/getMailingList.php?id=8&team=; paste to Mass Subscribe)
#Set mailing list (http://ogha.info/mailman/admin/peeweebb_ogha.info/members/add)
!Mailing List Welcome
This mailing list is for use by team members and the OGHA executive to share information about the team. Since it is a moderated list, there will be no spam.

If your email address changes, please update the OGHA site (use the pencil icon on the Family Page). Your team mailing list(s) will automatically be updated as well as the OGHA team contact list.

Remember to log in to ogha.info to see your team page and associated links (schedule, photo album, discussion area). Once the league statistics are available there will be a direct link to your team stats.

Good luck this season.

Janet Jansen
OGHA Webster
!Mailing List Goodbye
You have been removed from this list because we are updating the team mailing list. If it is the beginning of the season and you are on the same team as last year, you will be re-subscribed shortly.

If you have any questions, please let me know.

Janet Jansen
OGHA Webster

!Mailing Lists
http://ogha.info/mailman/admin/fundamentals_ogha.info/members/add					
http://ogha.info/mailman/admin/novice1_ogha.info/members/add					
http://ogha.info/mailman/admin/novice2_ogha.info/members/add					
http://ogha.info/mailman/admin/atom1_ogha.info/members/add					
http://ogha.info/mailman/admin/atom2_ogha.info/members/add					
http://ogha.info/mailman/admin/atom3_ogha.info/members/add					
http://ogha.info/mailman/admin/atombb_ogha.info/members/add					
http://ogha.info/mailman/admin/atomc_ogha.info/members/add					
http://ogha.info/mailman/admin/peewee1_ogha.info/members/add					
http://ogha.info/mailman/admin/peewee2_ogha.info/members/add					
http://ogha.info/mailman/admin/peewee3_ogha.info/members/add					
http://ogha.info/mailman/admin/peeweebb_ogha.info/members/add					
http://ogha.info/mailman/admin/peeweec_ogha.info/members/add					
http://ogha.info/mailman/admin/bantam1_ogha.info/members/add					
http://ogha.info/mailman/admin/bantam2_ogha.info/members/add					
http://ogha.info/mailman/admin/bantam3_ogha.info/members/add					
http://ogha.info/mailman/admin/bantama_ogha.info/members/add
http://ogha.info/mailman/admin/bantamb_ogha.info/members/add
http://ogha.info/mailman/admin/midget1_ogha.info/members/add
http://ogha.info/mailman/admin/midget2_ogha.info/members/add
http://ogha.info/mailman/admin/midget3_ogha.info/members/add
http://ogha.info/mailman/admin/midgetbb_ogha.info/members/add
http://ogha.info/mailman/admin/midgetb_ogha.info/members/add
http://ogha.info/mailman/admin/midgetc_ogha.info/members/add
http://ogha.info/mailman/admin/int1_ogha.info/members/add
http://ogha.info/mailman/admin/int2_ogha.info/members/add
http://ogha.info/mailman/admin/inta_ogha.info/members/add
http://mail.google.com/mail/?shva=1#label/OGHA+Mailing+Lists
#Set up team page: group, topic, static page, forum, & photo album 
##Create photo albums (Bantam & Midget HL**)
#Add players to team (Team Admin page)
#Set up site group (http://www.ogha.info/register/port/setTeamGroup.php?id=8&team=)
#Set team mailing list (http://www.ogha.info/register/port/getMailingList.php?id=8&team=)
#Assign team staff (http://www.ogha.info/register/port/addPlayerToTeam.php?id=8&team=&first=&last=&role=)
#Enter the jersey numbers (http://www.ogha.info/admin/plugins/register/index.php)
#Add [[stats fields|Set team stats links]]
#Get [[list of teams|Team IDs by team]] from Stephanie
#Add to jj_register_team with min/max/goalies
#[[Set up new team]]s
#Clear team forums (http://www.ogha.info/forum/index.php)
#Export the team lists (Tryouts, Goalies, Sortouts, [[MOGHL|Export to Excel on Team Admin page]], Gamesheet, Team Card)
#Find OWHA team numbers
#Find LeagueGM/Goalline team IDs: right click in LeagueGM on tab header for #s
!!!SQL for team inserts (CHECK forum for 58!)
INSERT INTO `gl_jj_register_team` (`registerID`, `teamID`, `regMin`, `regMax`, `goalies`, `name`, `forumID`, `gmOrgID`, `gmSeasonID`, `gmTeamID`, `gmElementID`, `owhaID`, `publish`) VALUES
(4, 37, 14, 16, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 1, 14, 16, 0, NULL, 6, 30, 90, 7412, NULL, 2018, 0),
(4, 2, 14, 16, 0, NULL, 13, NULL, NULL, NULL, NULL, NULL, 0),
(4, 3, 14, 17, 0, NULL, 14, NULL, NULL, NULL, NULL, NULL, 0),
(4, 4, 14, 16, 0, NULL, 15, NULL, NULL, NULL, NULL, NULL, 0),
(4, 5, 14, 16, 1, NULL, 18, NULL, NULL, NULL, NULL, NULL, 0),
(4, 6, 14, 16, 1, NULL, 16, NULL, NULL, NULL, NULL, NULL, 0),
(4, 7, 14, 15, 1, NULL, 17, NULL, NULL, NULL, NULL, NULL, 0),
(4, 8, 14, 16, 1, NULL, 19, NULL, NULL, NULL, NULL, NULL, 0),
(4, 9, 14, 16, 1, NULL, 20, NULL, NULL, NULL, NULL, NULL, 0),
(4, 10, 14, 15, 1, NULL, 22, NULL, NULL, NULL, NULL, NULL, 0),
(4, 11, 14, 15, 1, NULL, 23, NULL, NULL, NULL, NULL, NULL, 0),
(4, 12, 14, 16, 1, NULL, 40, NULL, NULL, NULL, NULL, NULL, 0),
(4, 13, 14, 15, 2, 'Ice', 30, NULL, NULL, NULL, NULL, NULL, 0),
(4, 15, 14, 15, 1, 'Ice', 43, NULL, NULL, NULL, NULL, NULL, 0),
(4, 17, 14, 15, 1, 'Ice', 33, NULL, NULL, NULL, NULL, NULL, 0),
(4, 18, 14, 14, 1, 'Ice', 34, NULL, NULL, NULL, NULL, NULL, 0),
(4, 20, 14, 15, 1, 'Ice', 35, NULL, NULL, NULL, NULL, NULL, 0),
(4, 21, 15, 17, 2, 'Ice', 36, NULL, NULL, NULL, NULL, 2004, 0),
(4, 23, 14, 16, 1, NULL, 21, NULL, NULL, NULL, NULL, NULL, 0),
(4, 25, 14, 16, 1, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 26, 14, 15, 1, 'Ice', 35, NULL, NULL, NULL, NULL, NULL, 0),
(4, 27, 13, 16, 1, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 29, 0, 0, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 30, 0, 0, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 31, 0, 0, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 32, 0, 0, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 33, 0, 0, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0),
(4, 34, 14, 14, 1, 'Ice', 31, NULL, NULL, NULL, NULL, NULL, 0),
(4, 35, 14, 14, 1, 'Ice', 33, NULL, NULL, NULL, NULL, NULL, 0),
(4, 36, 14, 14, 1, 'Ice', 32, NULL, NULL, NULL, NULL, NULL, 0),
(4, 38, 14, 14, 1, NULL, 46, NULL, NULL, NULL, NULL, NULL, 0),
(4, 58, 14, 14, 1, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0);
Hi ,

You can log in at ogha.info as  with password ogha2009.

For information about OGHA programs, please contact registrar@ogha.info. If you have questions about the site, let me know.

Janet Jansen
OGHA Webster
(You might want to these Someday/Maybe projects a tickler to remind you to review them at some point in the future)

<<mgtdList startTag:Project title:'Someday/Maybe projects without a tickler'
  tags:'!Complete && Someday/Maybe' view:Project mode:global
  where:!tiddler.hasTickler()
>>
order:2
button:s/m
buttonLong:someday/maybe
{{cols2{

{{col{

<<mgtdList title:'Someday/Maybe Projects' startTag:Project tags:'Someday/Maybe && !Complete' view:ProjectArea mode:global
	newButtonTags:'Project Someday/Maybe'
	>>

}}}

{{col{

<<mgtdList title:'Future Actions not in Projects' startTag:Action tags:'Future && !Done' view:Action mode:global
	group:Context
	gView:Context
	newButtonTags:'Action Future'
	where:!tiddler.hasParent('Project')
	>>


}}}

}}}

{{cols2{

{{col{

<<mgtdList title:'Starred Actions' startTag:Starred tags:'Action && !Done' view:ActionProj mode:global
	group:ActionStatus
	gView:bold
	newButtonTags:'Starred Action'
	>>

<<mgtdList title:'Starred Done Actions' startTag:Starred tags:'Done' view:DoneAction mode:global
	newButtonTags:'Starred Action Done'
	>>

}}}

{{col{

<<mgtdList title:'Starred Projects' startTag:Starred tags:'Project && !Complete' view:Project mode:global
	group:ProjectStatus
	gView:bold
	newButtonTags:'Starred Project'
	>>

<<mgtdList title:'Completed Projects' startTag:Starred tags:'Project && Complete' view:ProjectComplete mode:global
	newButtonTags:'Starred Project Complete'
	>>

<<mgtdList title:'Other Starred Items' startTag:Starred tags:'!Project && !Action' view:star mode:global
	group:GTDComponent
	gView:bold
	newButtonTags:'Starred'
	>>

}}}


}}}
<<mgtdList title:'Starred Next Actions by Context' startTag:Action tags:'Next && !Done && Starred' view:ActionProj mode:global
	group:Context
	newButtonTags:'Action Next Starred'
	where:tiddler.hasActiveProject()
>>

Wants to set up his email to show OGHA HL Convenor
jj_register_player
Check edit on Register Admin
table#datePickerTable td.datePickerNav {
    cursor:pointer;
}

.datePickerDaysHeader td {
    text-align:center;
    background:#ABABAB;
    font:100% Arial;
}

/*
.datePickerDayRow td {
    width:18px;
    height:18px;
}
*/

td#datePickerMNS, td.datePickerNav {
    font-weight:bold;
}

table#datePickerTable {
    position:absolute;
    /* border-collapse:collapse; */
    background:#FFFFFF;
    border:1px solid #000;
    display:none;   
}

table#datePickerTable td {
    padding: 3px;
}

td#datePickerMNS {
    text-align: center;
}

tr.datePickerDayRow td {
    background-color : #FFF;
    cursor : pointer;
    border : 1px solid #FFF;
    text-align : center;
	font-size:100%;
}

tr.datePickerDayRow td.defaultDate {
	color : #000;	
	text-decoration : none;   
}

tr.datePickerDayRow td.weekend {
	color:#797!important;
}

tr.datePickerDowRow td {
	color:#555;
	text-align:center;
	font-size:80%;
}

tr.datePickerDayRow td.emptyDate {
    cursor:default; 
}

tr.datePickerDayRow td.oldDate {
	color : #ABABAB;
    text-decoration : line-through;
}

tr.datePickerDayRow td.highlightedDate {
    background-color : #fcc;
	font-weight : bold;
	border:1px solid #622;
}
tr.datePickerDayRow td.highlightedDate.tdover {
	color : #000;
}

tr.datePickerDayRow td.todayDate {
	font-weight : bold;
	color : red;
}

table#datePickerTable tr.datePickerDayRow td.tdover {
    background:#fc6;
}

This isn't very good but it might be of some use. It's the best attempt we have at showing a list of subprojects.
<<mgtdList title:'Subprojects' startTag:Project tags:'Project && !Complete' view:Project mode:global
	where:tiddler.hasParent('Project')
	group:Project
	gView:bold
	newButtonTags:'Project Active'
	leftoverTitle:'(Projects that aren't subprojects)
	>>
PLEASE read this ENTIRE message to ensure that you complete the registration process correctly.

Registration Submission Confirmation - Work [[OGHA Online Payment]] 2008 Summer Hockey Program

Thank you for submitting your registration to the Ottawa Girls Hockey Association. By May 20th you will receive an email notifying you of the Group you will be in and what time you will be on the ice. Please note that groups will be formed based not only according to age, skill level will also be taken into account.

Note that incomplete registrations WILL NOT be accepted and will result in having to resubmit your registration, possibly affecting your guaranteed spot or your position on the waiting list.*
 ---- Details
from the actual online registration (date submitted, player name, age,
main contact etc - in other words "the usual")
 
The Work [[OGHA Online Payment]] registrar
must receive the following no later than May 15th please note, that if
you registered after May 15th, you will need to bring your payment to
the first session on May 25th.
 
---- Details from the actual online
registration regarding payment due

Please make cheque payable to
OGHA. Mailing Address: Work [[OGHA Online Payment]] - P.O. Box 40044, Ottawa, Ontario K1V
0W8


--------------------------------------------------------------------------------------------------

*
OGHA returning players who register by May 15 will be guaranteed a spot
(where numbers warrant and depending on the ice allocation received).
New players are placed on the waiting list in order of date and time
the online registration was submitted. Returning players who submit
their registrations after May 15 will be placed on the waiting list
with new players in order of date and time the online registration was
submitted.

After May 15th, the Work [[OGHA Online Payment]] will begin accepting players off
the waiting list in order of the date and time their registration was
submitted. Players on the waiting list will be notified as early as
possible when their spot is confirmed. No cheques will be cashed until
such time as a spot is confirmed and accepted.

If you have any
questions, please contact the Work [[OGHA Online Payment]] registrar at registration@OGHA.info.
Note that you can check your registration status and update your
contact information online at www.OGHA.info provided you are logged in
to the website.
!!!!Changes
*Change references to jjGetCurrentMember to jjCurrentMemberID
**admin/plugins/register/account.php
*Change Register to Family Page in Welcome Message
**lib-jems.php|jjWelcomeMessage 
**UPDATE `OGHAinfo_OGHA`.`mnu_index` SET `m_label` = 'Family Page' WHERE `mnu_index`.`m_id` =61 LIMIT 1 ;
*Update registration instructions for Programs Page
**gl/plugins/register/language/english.php
*Shows &nbsp; in registration email
**gl_program: shortForm
**lib-jems.php|jjProgramNameForID
*Don't want link on Groups
**lib-jems.php|jjGetTeamLink: && jjGetLevelID($teamID) <> 10

#Upgrade database:
**Download current database
**Change jeu(x) and fields in database
**Change jj_register in upgrade.sql so it only has summer for now and regStartDate is Apr 19 until it is working
**Take site down (notify Stephanie?)
**Run database upgrade code (upgrade.sql)
***''Note:'' Have to change levelID manually to 0 for Initiation
**Remove formsOutstanding (WVR,FPP) from last season in jj_register_player
#Copy code changes to server
**register
**schedule
**admin/plugins/register
**admin/plugins/schedule
**layout/OGHA/images/icons/OGHA.gif
**layout/OGHA/header.thtml
**gl/plugins/register
**gl/plugins/schedule
**system/lib-jems.php
**system/lib-custom.php
**javascript/jems.js
#Run admin/plugins/register/prepare.php to increment experience and clear teammates
** Add check for ones as Work [[OGHA Online Payment]] if not actually on Work [[OGHA Online Payment]] team last season (e.g., Withdrawn) ... make it None?
#Test
#Remove temporary settings for $email & $regEmail
#Send email to current members
TBD Novice 1=625
TBD Novice 2=721
TBD Atom 1=626
TBD Atom 2=647
TBD Atom 3=774
TBD Atom A=616
TBD Atom BB=637
TBD Atom B=652
TBD Peewee 1=629
TBD Peewee 2=776
TBD Peewee 3=781
TBD Peewee AA=727
TBD Peewee A=640
TBD Peewee BB=650
TBD Peewee B=607
TBD Peewee C=606
TBD Bantam 1=609
TBD Bantam 3=775
TBD Bantam A=730
TBD Bantam BB=608
TBD Bantam B=677
TBD Bantam C=605
TBD Midget 1=636
TBD Midget A=601
TBD Midget BB=602
TBD Midget B=645
TBD Midget C=603
TBD Midget/Int 1=633
TBD Intermediate 1=646
TBD Intermediate A=724
<<tiddler SideBarOptions>>
<<tiddler SideBarTabs>>
<<allTags excludeLists>>
<<tabs txtMoreTab "Tags" "All Tags" TabAllTags "Miss" "Missing tiddlers" TabMoreMissing "Orph" "Orphaned tiddlers" TabMoreOrphans "Shad" "Shadowed tiddlers" TabMoreShadowed>>
<<allTags excludeLists [a-z]>>
!Project
<!--{{{-->
<div class="cols3">

<div class="col">

	[[TagDashboards##Ticklers Requiring Action]]

	<div macro="mgtdList title:'Next Actions' tags:'Action && Next && !Done' view:Action
		ignoreRealm:yes
		group:Context
		gView:Context
		newButtonTags:'Action Next'
		"></div>

	<div macro="mgtdList title:'Waiting Actions by Person' tags:'Action && [(Waiting For)] && !Done' view:Action
		ignoreRealm:yes
		group:Contact
		gView:bold
		newButtonTags:'Action [(Waiting For)]'
		"></div>

</div>
<div class="col">

	<div macro="mgtdList title:'Active Subprojects' tags:'Project && !Complete' view:Project
		ignoreRealm:yes
		group:ProjectStatus
		gView:bold
		newButtonTags:'Project'
		"></div>

	<div macro="mgtdList title:'Completed Subprojects' tags:'Project && Complete' view:ProjectComplete
		ignoreRealm:yes
		newButtonTags:'Project Active Complete'
		dontShowEmpty:yes
		"></div>

	<div macro="mgtdList title:'Future Actions' tags:'Action && Future && !Done' view:Action
		ignoreRealm:yes
		group:Context
		gView:Context
		newButtonTags:'Action Future'
		"></div>


</div>
<div class="col">

	[[TagDashboards##Upcoming Ticklers]]

	<div macro="mgtdList title:'Reference Items' tags:'Reference' view:plain newButtonTags:'Reference' 
		ignoreRealm:yes
		"></div>

	<div macro="mgtdList title:'Done Actions' tags:'Action && Done' view:DoneAction
		ignoreRealm:yes
		newButtonTags:'Action Done Next'
		dontShowEmpty:yes
		sort:-modified
		"></div>

</div>

</div>
<!--}}}-->


!Context
<!--{{{-->
<div class="cols2">

<div class="col">

	<div macro="mgtdList title:'Next' tags:'Action && Next && !Done' view:ActionProj
		newButtonTags:'Action'
		where:tiddler.hasActiveProject()||!tiddler.hasParent('Project')
		"></div>

</div>
<div class="col">

	<div macro="mgtdList title:'Waiting' tags:'Action && [(Waiting For)] && !Done' view:ActionProj
		newButtonTags:'Action'
		where:tiddler.hasActiveProject()||!tiddler.hasParent('Project')
		"></div>

	<div macro="mgtdList title:'Future' tags:'Action && Future && !Done' view:ActionProj
		newButtonTags:'Future'
		where:tiddler.hasActiveProject()||!tiddler.hasParent('Project')
		"></div>

</div>

</div>
<!--}}}-->


!Contact
<!--{{{-->
<div class="cols2">

<div class="col">

	<div macro="mgtdList title:'Delegated Actions' tags:'Action && !Done && [(Waiting For)]' view:ActionProj
		ignoreRealm:yes
		newButtonTags:'Action [(Waiting For)]'
		"></div>

	<div macro="mgtdList title:'Associated Actions' tags:'Action && !Done && ![(Waiting For)]' view:ActionProj
		ignoreRealm:yes
		group:ActionStatus
		gView:bold
		newButtonTags:'Action'
		"></div>


</div>
<div class="col">

	<div macro="mgtdList title:'Associated Projects' tags:'Project && !Complete' view:Project
		ignoreRealm:yes
		group:ProjectStatus
		gView:bold
		newButtonTags:'Project'
		"></div>

	<div macro="mgtdList title:'Associated Ticklers' tags:'Tickler && !Actioned' view:Tickler
		ignoreRealm:yes
		newButtonTags:'Tickler Once'
		sort:tickleDate
		"></div>

	<div macro="mgtdList title:'Done Actions' tags:'Action && Done' view:DoneAction
		ignoreRealm:yes
		newButtonTags:Done
		"></div>

	<div macro="mgtdList title:'Completed Projects' tags:'Project && Complete' view:ProjectComplete
		ignoreRealm:yes
		newButtonTags:'Project'
		"></div>

</div>

</div>
<!--}}}-->


!Area
<!--{{{-->
<div class="cols3">

<div class="col">
	<div macro="mgtdList title:'Active Projects' tags:'Project && !Complete && !Someday/Maybe' view:Project newButtonTags:'Project Active'
		ignoreRealm:yes
		"></div>

	<!--
	for those who wanted actions in their area view
	comment the following out if you don't want it

	NB under construction, doesn't work at all...

	<div macro="mgtdList title:'Next Actions'
		mode:global
		startTag:Action
		tags:'!Done'
		group:ActionStatus
		gView:bold
		newButtonTags:'Action'
		view:Action
		where:{{'tiddler.actionInArea('+tiddler.title+')'}}
		ignoreRealm:yes
		"></div>
	-->
	
</div>
<div class="col">
	<div macro="mgtdList title:'Someday/Maybe Projects' tags:'Project && !Complete && Someday/Maybe' view:Project newButtonTags:'Project Someday/Maybe'
		ignoreRealm:yes
		"></div>
</div>
<div class="col">
	<div macro="mgtdList title:'Actions (without a project)'
		tags:'Action && !Done'
		view:Action
		newButtonTags:'Action' 
		group:ActionStatus
		gView:bold
		ignoreRealm:yes
		"></div>
	<div macro="mgtdList title:'Completed Projects' tags:'Project && Complete' view:ProjectComplete newButtonTags:'Project Someday/Maybe' 
		ignoreRealm:yes
		"></div>
</div>

</div>
<!--}}}-->


!Reference
<!--{{{-->
<div class="tagglyTagging" macro="tagglyTagging"></div><!--- this makes me happy :) --->
<!--}}}-->


!Ticklers Requiring Action
<!--{{{-->
<!--- included by other sections --->
<div macro="mgtdList title:'Ticklers Requiring Action' tags:'Tickler && !Actioned' view:Tickler newButtonTags:'Tickler Once'
	ignoreRealm:yes
	dontShowEmpty:yes
	where:'tiddler.ticklerIsActive()'
	sort:tickleDate
	"></div>
<!--}}}-->


!Upcoming Ticklers 
<!--{{{-->
<!--- included by other sections --->
<div macro="mgtdList title:'Upcoming Ticklers' tags:'Tickler && !Actioned' view:Tickler newButtonTags:'Tickler Once'
	ignoreRealm:yes
	where:'!tiddler.ticklerIsActive()'
	sort:tickleDate
	"></div>
<!--}}}-->



/***
|Name:|TagglyTaggingPlugin|
|Description:|tagglyTagging macro is a replacement for the builtin tagging macro in your ViewTemplate|
|Version:|3.3.1 ($Rev: 6100 $)|
|Date:|$Date: 2008-07-27 01:42:07 +1000 (Sun, 27 Jul 2008) $|
|Source:|http://mptw.tiddlyspot.com/#TagglyTaggingPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!Notes
See http://mptw.tiddlyspot.com/#TagglyTagging
***/
//{{{

merge(String.prototype,{

	parseTagExpr: function(debug) {

		if (this.trim() == "")
			return "(true)";

		var anyLogicOp = /(!|&&|\|\||\(|\))/g;
		var singleLogicOp = /^(!|&&|\|\||\(|\))$/;

		var spaced = this.
			// because square brackets in templates are no good
			// this means you can use [(With Spaces)] instead of [[With Spaces]]
			replace(/\[\(/g," [[").
			replace(/\)\]/g,"]] "). 
			// space things out so we can use readBracketedList. tricky eh?
			replace(anyLogicOp," $1 ");

		var expr = "";

		var tokens = spaced.readBracketedList(false); // false means don't uniq the list. nice one JR!

		for (var i=0;i<tokens.length;i++)
			if (tokens[i].match(singleLogicOp))
				expr += tokens[i];
			else
				expr += "tiddler.tags.contains('%0')".format([tokens[i].replace(/'/,"\\'")]); // fix single quote bug. still have round bracket bug i think

		if (debug)
			alert(expr);

		return '('+expr+')';
	}

});

merge(TiddlyWiki.prototype,{
	getTiddlersByTagExpr: function(tagExpr,sortField) {

		var result = [];

		var expr = tagExpr.parseTagExpr();

		store.forEachTiddler(function(title,tiddler) {
			if (eval(expr))
				result.push(tiddler);
		});

		if(!sortField)
			sortField = "title";

		result.sort(function(a,b) {return a[sortField] < b[sortField] ? -1 : (a[sortField] == b[sortField] ? 0 : +1);});
		
		return result;
	}
});

config.taggly = {

	// for translations
	lingo: {
		labels: {
			asc:        "\u2191", // down arrow
			desc:       "\u2193", // up arrow
			title:      "title",
			modified:   "modified",
			created:    "created",
			show:       "+",
			hide:       "-",
			normal:     "normal",
			group:      "group",
			commas:     "commas",
			sitemap:    "sitemap",
			numCols:    "cols\u00b1", // plus minus sign
			label:      "Tagged as '%0':",
			exprLabel:  "Matching tag expression '%0':",
			excerpts:   "excerpts",
			descr:      "descr",
			slices:     "slices",
			contents:   "contents",
			sliders:    "sliders",
			noexcerpts: "title only",
			noneFound:  "(none)"
		},

		tooltips: {
			title:      "Click to sort by title",
			modified:   "Click to sort by modified date",
			created:    "Click to sort by created date",
			show:       "Click to show tagging list",
			hide:       "Click to hide tagging list",
			normal:     "Click to show a normal ungrouped list",
			group:      "Click to show list grouped by tag",
			sitemap:    "Click to show a sitemap style list",
			commas:     "Click to show a comma separated list",
			numCols:    "Click to change number of columns",
			excerpts:   "Click to show excerpts",
			descr:      "Click to show the description slice",
			slices:     "Click to show all slices",
			contents:   "Click to show entire tiddler contents",
			sliders:    "Click to show tiddler contents in sliders",
			noexcerpts: "Click to show entire title only"
		},

		tooDeepMessage: "* //sitemap too deep...//"
	},

	config: {
		showTaggingCounts: true,
		listOpts: {
			// the first one will be the default
			sortBy:     ["title","modified","created"],
			sortOrder:  ["asc","desc"],
			hideState:  ["show","hide"],
			listMode:   ["normal","group","sitemap","commas"],
			numCols:    ["1","2","3","4","5","6"],
			excerpts:   ["noexcerpts","excerpts","descr","slices","contents","sliders"]
		},
		valuePrefix: "taggly.",
		excludeTags: ["excludeLists","excludeTagging"],
		excerptSize: 50,
		excerptMarker: "/%"+"%/",
		siteMapDepthLimit: 25
	},

	getTagglyOpt: function(title,opt) {
		var val = store.getValue(title,this.config.valuePrefix+opt);
		return val ? val : this.config.listOpts[opt][0];
	},

	setTagglyOpt: function(title,opt,value) {
		if (!store.tiddlerExists(title))
			// create it silently
			store.saveTiddler(title,title,config.views.editor.defaultText.format([title]),config.options.txtUserName,new Date(),"");
		// if value is default then remove it to save space
		return store.setValue(title,
			this.config.valuePrefix+opt,
			value == this.config.listOpts[opt][0] ? null : value);
	},

	getNextValue: function(title,opt) {
		var current = this.getTagglyOpt(title,opt);
		var pos = this.config.listOpts[opt].indexOf(current);
		// a little usability enhancement. actually it doesn't work right for grouped or sitemap
		var limit = (opt == "numCols" ? store.getTiddlersByTagExpr(title).length : this.config.listOpts[opt].length);
		var newPos = (pos + 1) % limit;
		return this.config.listOpts[opt][newPos];
	},

	toggleTagglyOpt: function(title,opt) {
		var newVal = this.getNextValue(title,opt);
		this.setTagglyOpt(title,opt,newVal);
	}, 

	createListControl: function(place,title,type) {
		var lingo = config.taggly.lingo;
		var label;
		var tooltip;
		var onclick;

		if ((type == "title" || type == "modified" || type == "created")) {
			// "special" controls. a little tricky. derived from sortOrder and sortBy
			label = lingo.labels[type];
			tooltip = lingo.tooltips[type];

			if (this.getTagglyOpt(title,"sortBy") == type) {
				label += lingo.labels[this.getTagglyOpt(title,"sortOrder")];
				onclick = function() {
					config.taggly.toggleTagglyOpt(title,"sortOrder");
					return false;
				}
			}
			else {
				onclick = function() {
					config.taggly.setTagglyOpt(title,"sortBy",type);
					config.taggly.setTagglyOpt(title,"sortOrder",config.taggly.config.listOpts.sortOrder[0]);
					return false;
				}
			}
		}
		else {
			// "regular" controls, nice and simple
			label = lingo.labels[type == "numCols" ? type : this.getNextValue(title,type)];
			tooltip = lingo.tooltips[type == "numCols" ? type : this.getNextValue(title,type)];
			onclick = function() {
				config.taggly.toggleTagglyOpt(title,type);
				return false;
			}
		}

		// hide button because commas don't have columns
		if (!(this.getTagglyOpt(title,"listMode") == "commas" && type == "numCols"))
			createTiddlyButton(place,label,tooltip,onclick,type == "hideState" ? "hidebutton" : "button");
	},

	makeColumns: function(orig,numCols) {
		var listSize = orig.length;
		var colSize = listSize/numCols;
		var remainder = listSize % numCols;

		var upperColsize = colSize;
		var lowerColsize = colSize;

		if (colSize != Math.floor(colSize)) {
			// it's not an exact fit so..
			upperColsize = Math.floor(colSize) + 1;
			lowerColsize = Math.floor(colSize);
		}

		var output = [];
		var c = 0;
		for (var j=0;j<numCols;j++) {
			var singleCol = [];
			var thisSize = j < remainder ? upperColsize : lowerColsize;
			for (var i=0;i<thisSize;i++) 
				singleCol.push(orig[c++]);
			output.push(singleCol);
		}

		return output;
	},

	drawTable: function(place,columns,theClass) {
		var newTable = createTiddlyElement(place,"table",null,theClass);
		var newTbody = createTiddlyElement(newTable,"tbody");
		var newTr = createTiddlyElement(newTbody,"tr");
		for (var j=0;j<columns.length;j++) {
			var colOutput = "";
			for (var i=0;i<columns[j].length;i++) 
				colOutput += columns[j][i];
			var newTd = createTiddlyElement(newTr,"td",null,"tagglyTagging"); // todo should not need this class
			wikify(colOutput,newTd);
		}
		return newTable;
	},

	createTagglyList: function(place,title,isTagExpr) {
		switch(this.getTagglyOpt(title,"listMode")) {
			case "group":  return this.createTagglyListGrouped(place,title,isTagExpr); break;
			case "normal": return this.createTagglyListNormal(place,title,false,isTagExpr); break;
			case "commas": return this.createTagglyListNormal(place,title,true,isTagExpr); break;
			case "sitemap":return this.createTagglyListSiteMap(place,title,isTagExpr); break;
		}
	},

	getTaggingCount: function(title,isTagExpr) {
		// thanks to Doug Edmunds
		if (this.config.showTaggingCounts) {
			var tagCount = config.taggly.getTiddlers(title,'title',isTagExpr).length;
			if (tagCount > 0)
				return " ("+tagCount+")";
		}
		return "";
	},

	getTiddlers: function(titleOrExpr,sortBy,isTagExpr) {
		return isTagExpr ? store.getTiddlersByTagExpr(titleOrExpr,sortBy) : store.getTaggedTiddlers(titleOrExpr,sortBy);
	},

	getExcerpt: function(inTiddlerTitle,title,indent) {
		if (!indent)
			indent = 1;

		var displayMode = this.getTagglyOpt(inTiddlerTitle,"excerpts");
		var t = store.getTiddler(title);

		if (t && displayMode == "excerpts") {
			var text = t.text.replace(/\n/," ");
			var marker = text.indexOf(this.config.excerptMarker);
			if (marker != -1) {
				return " {{excerpt{<nowiki>" + text.substr(0,marker) + "</nowiki>}}}";
			}
			else if (text.length < this.config.excerptSize) {
				return " {{excerpt{<nowiki>" + t.text + "</nowiki>}}}";
			}
			else {
				return " {{excerpt{<nowiki>" + t.text.substr(0,this.config.excerptSize) + "..." + "</nowiki>}}}";
			}
		}
		else if (t && displayMode == "contents") {
			return "\n{{contents indent"+indent+"{\n" + t.text + "\n}}}";
		}
		else if (t && displayMode == "sliders") {
			return "<slider slide>\n{{contents{\n" + t.text + "\n}}}\n</slider>";
		}
		else if (t && displayMode == "descr") {
			var descr = store.getTiddlerSlice(title,'Description');
			return descr ? " {{excerpt{" + descr  + "}}}" : "";
		}
		else if (t && displayMode == "slices") {
			var result = "";
			var slices = store.calcAllSlices(title);
			for (var s in slices)
				result += "|%0|<nowiki>%1</nowiki>|\n".format([s,slices[s]]);
			return result ? "\n{{excerpt excerptIndent{\n" + result  + "}}}" : "";
		}
		return "";
	},

	notHidden: function(t,inTiddler) {
		if (typeof t == "string") 
			t = store.getTiddler(t);
		return (!t || !t.tags.containsAny(this.config.excludeTags) ||
				(inTiddler && this.config.excludeTags.contains(inTiddler)));
	},

	// this is for normal and commas mode
	createTagglyListNormal: function(place,title,useCommas,isTagExpr) {

		var list = config.taggly.getTiddlers(title,this.getTagglyOpt(title,"sortBy"),isTagExpr);

		if (this.getTagglyOpt(title,"sortOrder") == "desc")
			list = list.reverse();

		var output = [];
		var first = true;
		for (var i=0;i<list.length;i++) {
			if (this.notHidden(list[i],title)) {
				var countString = this.getTaggingCount(list[i].title);
				var excerpt = this.getExcerpt(title,list[i].title);
				if (useCommas)
					output.push((first ? "" : ", ") + "[[" + list[i].title + "]]" + countString + excerpt);
				else
					output.push("*[[" + list[i].title + "]]" + countString + excerpt + "\n");

				first = false;
			}
		}

		return this.drawTable(place,
			this.makeColumns(output,useCommas ? 1 : parseInt(this.getTagglyOpt(title,"numCols"))),
			useCommas ? "commas" : "normal");
	},

	// this is for the "grouped" mode
	createTagglyListGrouped: function(place,title,isTagExpr) {
		var sortBy = this.getTagglyOpt(title,"sortBy");
		var sortOrder = this.getTagglyOpt(title,"sortOrder");

		var list = config.taggly.getTiddlers(title,sortBy,isTagExpr);

		if (sortOrder == "desc")
			list = list.reverse();

		var leftOvers = []
		for (var i=0;i<list.length;i++)
			leftOvers.push(list[i].title);

		var allTagsHolder = {};
		for (var i=0;i<list.length;i++) {
			for (var j=0;j<list[i].tags.length;j++) {

				if (list[i].tags[j] != title) { // not this tiddler

					if (this.notHidden(list[i].tags[j],title)) {

						if (!allTagsHolder[list[i].tags[j]])
							allTagsHolder[list[i].tags[j]] = "";

						if (this.notHidden(list[i],title)) {
							allTagsHolder[list[i].tags[j]] += "**[["+list[i].title+"]]"
										+ this.getTaggingCount(list[i].title) + this.getExcerpt(title,list[i].title) + "\n";

							leftOvers.setItem(list[i].title,-1); // remove from leftovers. at the end it will contain the leftovers

						}
					}
				}
			}
		}

		var allTags = [];
		for (var t in allTagsHolder)
			allTags.push(t);

		var sortHelper = function(a,b) {
			if (a == b) return 0;
			if (a < b) return -1;
			return 1;
		};

		allTags.sort(function(a,b) {
			var tidA = store.getTiddler(a);
			var tidB = store.getTiddler(b);
			if (sortBy == "title") return sortHelper(a,b);
			else if (!tidA && !tidB) return 0;
			else if (!tidA) return -1;
			else if (!tidB) return +1;
			else return sortHelper(tidA[sortBy],tidB[sortBy]);
		});

		var leftOverOutput = "";
		for (var i=0;i<leftOvers.length;i++)
			if (this.notHidden(leftOvers[i],title))
				leftOverOutput += "*[["+leftOvers[i]+"]]" + this.getTaggingCount(leftOvers[i]) + this.getExcerpt(title,leftOvers[i]) + "\n";

		var output = [];

		if (sortOrder == "desc")
			allTags.reverse();
		else if (leftOverOutput != "")
			// leftovers first...
			output.push(leftOverOutput);

		for (var i=0;i<allTags.length;i++)
			if (allTagsHolder[allTags[i]] != "")
				output.push("*[["+allTags[i]+"]]" + this.getTaggingCount(allTags[i]) + this.getExcerpt(title,allTags[i]) + "\n" + allTagsHolder[allTags[i]]);

		if (sortOrder == "desc" && leftOverOutput != "")
			// leftovers last...
			output.push(leftOverOutput);

		return this.drawTable(place,
				this.makeColumns(output,parseInt(this.getTagglyOpt(title,"numCols"))),
				"grouped");

	},

	// used to build site map
	treeTraverse: function(title,depth,sortBy,sortOrder,isTagExpr) {

		var list = config.taggly.getTiddlers(title,sortBy,isTagExpr);

		if (sortOrder == "desc")
			list.reverse();

		var indent = "";
		for (var j=0;j<depth;j++)
			indent += "*"

		var childOutput = "";

		if (depth > this.config.siteMapDepthLimit)
			childOutput += indent + this.lingo.tooDeepMessage;
		else
			for (var i=0;i<list.length;i++)
				if (list[i].title != title)
					if (this.notHidden(list[i].title,this.config.inTiddler))
						childOutput += this.treeTraverse(list[i].title,depth+1,sortBy,sortOrder,false);

		if (depth == 0)
			return childOutput;
		else
			return indent + "[["+title+"]]" + this.getTaggingCount(title) + this.getExcerpt(this.config.inTiddler,title,depth) + "\n" + childOutput;
	},

	// this if for the site map mode
	createTagglyListSiteMap: function(place,title,isTagExpr) {
		this.config.inTiddler = title; // nasty. should pass it in to traverse probably
		var output = this.treeTraverse(title,0,this.getTagglyOpt(title,"sortBy"),this.getTagglyOpt(title,"sortOrder"),isTagExpr);
		return this.drawTable(place,
				this.makeColumns(output.split(/(?=^\*\[)/m),parseInt(this.getTagglyOpt(title,"numCols"))), // regexp magic
				"sitemap"
				);
	},

	macros: {
		tagglyTagging: {
			handler: function (place,macroName,params,wikifier,paramString,tiddler) {
				var parsedParams = paramString.parseParams("tag",null,true);
				var refreshContainer = createTiddlyElement(place,"div");

				// do some refresh magic to make it keep the list fresh - thanks Saq
				refreshContainer.setAttribute("refresh","macro");
				refreshContainer.setAttribute("macroName",macroName);

				var tag = getParam(parsedParams,"tag");
				var expr = getParam(parsedParams,"expr");

				if (expr) {
					refreshContainer.setAttribute("isTagExpr","true");
					refreshContainer.setAttribute("title",expr);
					refreshContainer.setAttribute("showEmpty","true");
				}
				else {
					refreshContainer.setAttribute("isTagExpr","false");
					if (tag) {
        				refreshContainer.setAttribute("title",tag);
						refreshContainer.setAttribute("showEmpty","true");
					}
					else {
        				refreshContainer.setAttribute("title",tiddler.title);
						refreshContainer.setAttribute("showEmpty","false");
					}
				}
				this.refresh(refreshContainer);
			},

			refresh: function(place) {
				var title = place.getAttribute("title");
				var isTagExpr = place.getAttribute("isTagExpr") == "true";
				var showEmpty = place.getAttribute("showEmpty") == "true";
				removeChildren(place);
				addClass(place,"tagglyTagging");
				var countFound = config.taggly.getTiddlers(title,'title',isTagExpr).length
				if (countFound > 0 || showEmpty) {
					var lingo = config.taggly.lingo;
					config.taggly.createListControl(place,title,"hideState");
					if (config.taggly.getTagglyOpt(title,"hideState") == "show") {
						createTiddlyElement(place,"span",null,"tagglyLabel",
								isTagExpr ? lingo.labels.exprLabel.format([title]) : lingo.labels.label.format([title]));
						config.taggly.createListControl(place,title,"title");
						config.taggly.createListControl(place,title,"modified");
						config.taggly.createListControl(place,title,"created");
						config.taggly.createListControl(place,title,"listMode");
						config.taggly.createListControl(place,title,"excerpts");
						config.taggly.createListControl(place,title,"numCols");
						config.taggly.createTagglyList(place,title,isTagExpr);
						if (countFound == 0 && showEmpty)
							createTiddlyElement(place,"div",null,"tagglyNoneFound",lingo.labels.noneFound);
					}
				}
			}
		}
	},

	// todo fix these up a bit
	styles: [
"/*{{{*/",
"/* created by TagglyTaggingPlugin */",
".tagglyTagging { padding-top:0.5em; }",
".tagglyTagging li.listTitle { display:none; }",
".tagglyTagging ul {",
"	margin-top:0px; padding-top:0.5em; padding-left:2em;",
"	margin-bottom:0px; padding-bottom:0px;",
"}",
".tagglyTagging { vertical-align: top; margin:0px; padding:0px; }",
".tagglyTagging table { margin:0px; padding:0px; }",
".tagglyTagging .button { visibility:hidden; margin-left:3px; margin-right:3px; }",
".tagglyTagging .button, .tagglyTagging .hidebutton {",
"	color:[[ColorPalette::TertiaryLight]]; font-size:90%;",
"	border:0px; padding-left:0.3em;padding-right:0.3em;",
"}",
".tagglyTagging .button:hover, .hidebutton:hover, ",
".tagglyTagging .button:active, .hidebutton:active  {",
"	border:0px; background:[[ColorPalette::TertiaryPale]]; color:[[ColorPalette::TertiaryDark]];",
"}",
".selected .tagglyTagging .button { visibility:visible; }",
".tagglyTagging .hidebutton { color:[[ColorPalette::Background]]; }",
".selected .tagglyTagging .hidebutton { color:[[ColorPalette::TertiaryLight]] }",
".tagglyLabel { color:[[ColorPalette::TertiaryMid]]; font-size:90%; }",
".tagglyTagging ul {padding-top:0px; padding-bottom:0.5em; margin-left:1em; }",
".tagglyTagging ul ul {list-style-type:disc; margin-left:-1em;}",
".tagglyTagging ul ul li {margin-left:0.5em; }",
".editLabel { font-size:90%; padding-top:0.5em; }",
".tagglyTagging .commas { padding-left:1.8em; }",
"/* not technically tagglytagging but will put them here anyway */",
".tagglyTagged li.listTitle { display:none; }",
".tagglyTagged li { display: inline; font-size:90%; }",
".tagglyTagged ul { margin:0px; padding:0px; }",
".excerpt { color:[[ColorPalette::TertiaryDark]]; }",
".excerptIndent { margin-left:4em; }",
"div.tagglyTagging table,",
"div.tagglyTagging table tr,",
"td.tagglyTagging",
" {border-style:none!important; }",
".tagglyTagging .contents { border-bottom:2px solid [[ColorPalette::TertiaryPale]]; padding:0 1em 1em 0.5em;",
"  margin-bottom:0.5em; }",
".tagglyTagging .indent1  { margin-left:3em;  }",
".tagglyTagging .indent2  { margin-left:4em;  }",
".tagglyTagging .indent3  { margin-left:5em;  }",
".tagglyTagging .indent4  { margin-left:6em;  }",
".tagglyTagging .indent5  { margin-left:7em;  }",
".tagglyTagging .indent6  { margin-left:8em;  }",
".tagglyTagging .indent7  { margin-left:9em;  }",
".tagglyTagging .indent8  { margin-left:10em; }",
".tagglyTagging .indent9  { margin-left:11em; }",
".tagglyTagging .indent10 { margin-left:12em; }",
".tagglyNoneFound { margin-left:2em; color:[[ColorPalette::TertiaryMid]]; font-size:90%; font-style:italic; }",
"/*}}}*/",
		""].join("\n"),

	init: function() {
		merge(config.macros,this.macros);
		config.shadowTiddlers["TagglyTaggingStyles"] = this.styles;
		store.addNotification("TagglyTaggingStyles",refreshStyles);
	}
};

config.taggly.init();

//}}}

/***
InlineSlidersPlugin
By Saq Imtiaz
http://tw.lewcid.org/sandbox/#InlineSlidersPlugin

// syntax adjusted to not clash with NestedSlidersPlugin
// added + syntax to start open instead of closed

***/
//{{{
config.formatters.unshift( {
	name: "inlinesliders",
	// match: "\\+\\+\\+\\+|\\<slider",
	match: "\\<slider",
	// lookaheadRegExp: /(?:\+\+\+\+|<slider) (.*?)(?:>?)\n((?:.|\n)*?)\n(?:====|<\/slider>)/mg,
	lookaheadRegExp: /(?:<slider)(\+?) (.*?)(?:>)\n((?:.|\n)*?)\n(?:<\/slider>)/mg,
	handler: function(w) {
		this.lookaheadRegExp.lastIndex = w.matchStart;
		var lookaheadMatch = this.lookaheadRegExp.exec(w.source)
		if(lookaheadMatch && lookaheadMatch.index == w.matchStart ) {
			var btn = createTiddlyButton(w.output,lookaheadMatch[2] + " "+"\u00BB",lookaheadMatch[2],this.onClickSlider,"button sliderButton");
			var panel = createTiddlyElement(w.output,"div",null,"sliderPanel");
			panel.style.display = (lookaheadMatch[1] == '+' ? "block" : "none");
			wikify(lookaheadMatch[3],panel);
			w.nextMatch = lookaheadMatch.index + lookaheadMatch[0].length;
		}
   },
   onClickSlider : function(e) {
		if(!e) var e = window.event;
		var n = this.nextSibling;
		n.style.display = (n.style.display=="none") ? "block" : "none";
		return false;
	}
});

//}}}

/***
|Name|TaskTimerPlugin|
|Source|http://www.TiddlyTools.com/#TaskTimerPlugin|
|Documentation|http://www.TiddlyTools.com/#TaskTimerPluginInfo|
|Version|1.4.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Requires||
|Overrides||
|Options|##Configuration|
|Description|'timer' button automatically writes start/end/elapsed time into tiddler content|
Quickly generate 'timed task' logs that can be used for status reports, billing purposes, etc.  
!!!!!Documentation
> see [[TaskTimerPluginInfo]]
!!!!!Configuration
> see [[TaskTimerPluginConfig]]
!!!!!Revisions
<<<
2008.11.10 [1.4.1] in elapsed time calculation, truncate start/stop times to nearest second (avoids 1-second 'round-down' error)
|please see [[TaskTimerPluginInfo]] for additional revision details|
2007.03.14 [0.5.0] converted from inline script
<<<
!!!!!Code
***/
//{{{
version.extensions.TaskTimerPlugin= {major: 1, minor:4, revision: 1, date: new Date(2008,11,10)};

config.macros.taskTimer = {
	label: "start timer",
	title: "press to start the task timer",
	format: "|%4|%0|%1|%2|%3|\\n", // note: double-backslash-en, also date is %4 (for backward compatibility)
	defText: " ", // default description text
	todayKeyword: "today",
	todayFormat: "0MM/0DD/YYYY", // default format - superceded by CalendarPlugin, DatePlugin, or DatePluginConfig
	datestampFormat: "YYYY-0MM-0DD", // date stamp format
	buttonFormat: "%0 - %2",  // timer button formats: %0=current time, %1=start time, %2=elapsed time
	defHeader: "|//Date//|//Description//|//Started//|//Stopped//|//Elapsed//|\n",
	defTarget: "ActivityReport",
	descrMsg: "Enter a short description for this activity.  Press [cancel] to continue timer.",
	askMsg: "Enter the title of a tiddler in which to record this activity.  Press [cancel] to continue timer.",
	errMsg: "'%0' is not a valid tiddler title.  Please try again...\n\n",
	createdMsg: "'%0' has been created",
	updatedMsg: "'%0' has been updated",
	marker: "/%"+"tasktimer"+"%/",
	tag: "Today",
	handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		var target=params.shift(); // get optional target tiddler title
		if (!target) target="";
		var format=this.format; if (params[0]) format=params.shift(); // get optional output format
		var descrMsg=this.descrMsg; if (params[0]) descrMsg=params.shift(); // get optional message text
		var defText=this.defText; if (params[0]) defText=params.shift(); // get optional default text
		var onclick="config.macros.taskTimer.toggle(this,'"+target+"','"+format+"','"+descrMsg+"','"+defText+"')";
		createTiddlyElement(place,"span").innerHTML =
			'<input type="button" value="start timer" title="'+this.title+'" onclick="'+onclick+'">';
	},
	toggle: function(here,target,format,msg,defText) {
		if (!target || !target.length || target=="here") {
			var  tid=story.findContainingTiddler(here);
			target=tid?tid.getAttribute("tiddler"):"ask";
		}
		if (!here.running) { // not running... start timer...
			here.startTime=new Date();
			var now=here.startTime.formatString("0hh:0mm:0ss");
			here.title=(here.target||target)+" - started at "+now;
			here.value=this.buttonFormat.format([now,now,"00:00:00"]);
			here.id=new Date().getTime()+Math.random().toString(); // unique ID
			here.ticker=setTimeout("config.macros.taskTimer.tick('"+here.id+"')",500);
			here.running=true;
		} else {
			if (target=="ask") {
				target=prompt(this.askMsg,here.target||this.defTarget);
				while (target && !target.trim().length)
					target=prompt(this.errMsg.format([target])+this.askMsg,here.target||this.defTarget);
				if (!target) return; // user cancelled input...  continue timer
			}
			var txt=prompt(msg,defText); // get description from user
			if (!txt) return; // user cancelled input...  continue timer
			if (target==this.todayKeyword || target.substr(0,this.todayKeyword.length+1)==this.todayKeyword+":")
				target=(new Date()).formatString(this.getJournalFormat(target));
			here=document.getElementById(here.id); // RE-get button element after timer has stopped...
			clearTimeout(here.ticker);
			here.target=target;
			var before=this.defHeader;
			var after=this.marker+"\n";
			var tiddler=store.getTiddler(here.target);
			if (tiddler && tiddler.text.length) {
				var pos=tiddler.text.indexOf(this.marker);
				if (pos==-1) pos=tiddler.text.length; // no marker, append content to end
				var before=tiddler.text.substr(0,pos); // everything up to marker
				if (before.length&&before.substr(before.length-1)!="\n") before+="\n"; // start on a new line
				var after=tiddler.text.substr(pos); // marker+everything else
			}
			var now=new Date(Math.floor(new Date()/1000)*1000);
			var then=new Date(Math.floor(here.startTime/1000)*1000);
			var diff=new Date(now-then);
			var s=diff.getUTCSeconds(); if (s<10) s="0"+s;
			var m=diff.getUTCMinutes(); if (m<10) m="0"+m;
			var h=diff.getUTCHours(); if (h<10) h="0"+h;
			var start=then.formatString("0hh:0mm:0ss");
			var stop=now.formatString("0hh:0mm:0ss");
			var elapsed=h+":"+m+":"+s;
			var dateStamp=now.formatString(config.macros.taskTimer.datestampFormat);
			var newtxt=before+format.format([txt,start,stop,elapsed,dateStamp])+after;
			var newtags=(tiddler?tiddler.tags:['Today'], tiddler?tiddler.tags:['task'], tiddler?tiddler.tags:['Reference']); // include 'task' tag when creating new tiddlers
			store.saveTiddler(here.target,here.target,newtxt,config.options.txtUserName,new Date(),newtags,tiddler?tiddler.fields:null);
			if (!tiddler) displayMessage(this.createdMsg.format([here.target]));
			else displayMessage(this.updatedMsg.format([here.target]));
			here.running=false;
			here.value=this.label;
			here.title=this.title;
			var  tid=story.findContainingTiddler(here);
			if (!tid || tid.getAttribute("tiddler")!=target) // display target tiddler, but only when button is not IN the target tiddler
				{ story.displayTiddler(story.findContainingTiddler(here),here.target); story.refreshTiddler(here.target,1,true); }
		}
	},
	tick: function(id) {
		var here=document.getElementById(id); if (!here) return;
		var now=new Date();
		var diff=new Date(now-here.startTime);
		var s=diff.getUTCSeconds(); if (s<10) s="0"+s;
		var m=diff.getUTCMinutes();  if (m<10) m="0"+m;
		var h=diff.getUTCHours();  if (h<10) h="0"+h;
		var elapsed=h+":"+m+":"+s;
		now=now.formatString("0hh:0mm:0ss");
		var start=here.startTime.formatString("0hh:0mm:0ss");
		here.value=this.buttonFormat.format([now,start,elapsed]);
		here.ticker=setTimeout("config.macros.taskTimer.tick('"+id+"')",500);
	},
	getJournalFormat: function(target) {
		var fmt=target.split(":"); fmt.shift(); fmt=fmt.join(":");
		if (!fmt || !fmt.length) { // if date format was not specified
			if (config.macros.date)  // if installed, use default from DatePlugin
				fmt=config.macros.date.linkformat;
			if (config.macros.calendar) { // if installed, use default from CalendarPlugin
				if (!config.macros.date) // hard-coded calendar fallback if no DatePlugin
					fmt=config.macros.calendar.tiddlerformat;
				else // journalDateFmt is set when calendar is rendered with DatePlugin
					fmt=config.macros.calendar.journalDateFmt;
			}
		}
		if (!fmt) { // if not specified and no DatePlugin/CalendarPlugin
			// get format from <<newJournal>> in SideBarOptions
			var text = store.getTiddlerText("SideBarOptions");
			var re=new RegExp("<<(?:newJournal)([^>]*)>>","mg"); var fm=re.exec(text);
			if (fm && fm[1]!=null) { var pa=fm[1].readMacroParams(); if (pa[0]) fmt = pa[0]; }
		}
		if (!fmt) var fmt=this.todayFormat; // no "newJournal"... final fallback.
		return fmt;
	}
}
//}}}
// default target tiddler title (when 'ask' option is used)
config.macros.taskTimer.defTarget="ActivityReport";

// table heading (when creating **new** target tiddlers only)
config.macros.taskTimer.defHeader="|//Date//|//Description//|//Started//|//Elapsed//|\n";

// note: double-backslash-en, also datestamp is %4 (for backward compatibility)
config.macros.taskTimer.format="|%4|%0|%1|%3|\\n";

// date stamp format (used with %4, above)
config.macros.taskTimer.datestampFormat="YYYY-mmm-0DD";

// default description text - note: do not use empty string (e.g., "")
config.macros.taskTimer.defText=" ";

// format for target tiddler title (when "today" option is used)
// otherwise, use format from CalendarPlugin, DatePlugin, DatePluginConfig,
// or <<newJournal>> macro embedded in SideBarOptions
config.macros.taskTimer.todayFormat="YYYY-mmm-0DD";

// marker for locating 'insertion point' in target tiddler
config.macros.taskTimer.marker="/%tasktimer%/";
TeamID (lev, div)
1 (2 1) = Novice 1
2 (2 2) = Novice 2
3 (3 1) = Atom 1
4 (3 2) = Atom 2
5 (3 3) = Atom 3
6 (4 1) = Peewee 1
7 (4 2) = Peewee 2
8 (5 1) = Bantam 1
9 (5 2) = Bantam 2
10 (6 1) = Midget 1
11 (6 2) = Midget 2
12 (8 1) = Intermediate 1
13 (3 103) = Atom BB
14 (4 104) = Peewee B
15 (4 105) = Peewee C
16 (5 103) = Bantam BB
17 (5 105) = Bantam C
18 (6 102) = Midget A
19 (6 103) = Midget BB
20 (6 105) = Midget C
21 (8 102) = Intermediate A
22 (3 105) = Atom C
23 (5 3) = Bantam 3
24 (2 3) = Novice 3
25 (4 3) = Peewee 3
26 (6 104) = Midget B
27 (8 2) = Intermediate 2
28 (2 0) = Novice HL
29 (3 0) = Atom HL
30 (4 0) = Peewee HL
31 (5 0) = Bantam HL
32 (6 0) = Midget HL
33 (8 0) = Intermediate HL
34 (4 103) = Peewee BB
35 (5 104) = Bantam B
36 (5 102) = Bantam A
37 (1 1) = Fundamentals 1
38 (6 3) = Midget 3
39 (3 104) = Atom B
40 (4 102) = Peewee A
41 (8 103) = Intermediate BB
42 (3 102) = Atom A
51 (11 1) = Group 1
52 (11 2) = Group 2
53 (11 3) = Group 3
54 (11 4) = Group 4
55 (11 5) = Group 5
56 (11 6) = Group 6
57 (11 7) = Group 7
58 (8 3) = Intermediate 3
!!Team IDs (levelID, divID)
Atom A = 42 (3,102)
Atom BB = 13 (3,103)
Atom B = 39 (3,104)
Atom C = 22 (3,105)
Peewee A = 40 (4,102)
Peewee BB = 34 (4,103)
Peewee B = 14 (4,104)
Peewee C = 15 (4,105)
Bantam A = 36 (5,102)
Bantam BB = 16 (5,103)
Bantam B = 35 (5,104)
Bantam C = 17 (5,105)
Midget A = 18 (6,102)
Midget BB = 19 (6,103)
Midget B = 26 (6,104)
Midget C = 20 (6,105)
Intermediate A = 21 (8,102)
Intermediate BB = 41 (8,103)
Fundamentals 1 = 37 (1,1)
Novice HL = 28 (2,0)
Novice 1 = 1 (2,1)
Novice 2 = 2 (2,2)
Novice 3 = 24 (2,3)
Atom HL = 29 (3,0)
Atom 1 = 3 (3,1)
Atom 2 = 4 (3,2)
Atom 3 = 5 (3,3)
Peewee HL = 30 (4,0)
Peewee 1 = 6 (4,1)
Peewee 2 = 7 (4,2)
Peewee 3 = 25 (4,3)
Bantam HL = 31 (5,0)
Bantam 1 = 8 (5,1)
Bantam 2 = 9 (5,2)
Bantam 3 = 23 (5,3)
Midget HL = 32 (6,0)
Midget 1 = 10 (6,1)
Midget 2 = 11 (6,2)
Midget 3 = 38 (6,3)
Intermediate HL = 33 (8,0)
Intermediate 1 = 12 (8,1)
Intermediate 2 = 27 (8,2)
Intermediate 3 = 58 (8,3)
Group 1 = 51 (11,1)
Group 2 = 52 (11,2)
Group 3 = 53 (11,3)
Group 4 = 54 (11,4)
Group 5 = 55 (11,5)
Group 6 = 56 (11,6)
Group 7 = 57 (11,7)

{{cols2{

{{col{

<<tiddler 'Ticklers Requiring Action'>>

<<mgtdList title:'Upcoming Ticklers'
	startTag:Tickler
	tags:'!Actioned'
	view:Tickler
	mode:global
	newButtonTags:'Tickler Once'
	where:'!tiddler.fields.mgtd_date || !tiddler.ticklerIsActive()'
	sort:'tickleDate'
	ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
	>>

}}}

{{col{

<<mgtdList
	title:'Old Ticklers'
	startTag:Tickler
	tags:'Actioned'
	view:Tickler
	mode:global
	newButtonTags:'Tickler Actioned Once'
	>>

}}}

}}}
{{cols2{

{{col{


<<mgtdList
    title:'Ticklers Requiring Action Grouped'
    startTag:Tickler
    tags:'!Actioned'
    view:Tickler
    group:Contact
    gView:bold
    mode:global
    newButtonTags:'Tickler Enabled Once'
    where:'tiddler.ticklerIsActive()'
    sort:'tickleDate'
    dontShowEmpty:yes
    ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>

}}}

{{col{

<<mgtdList
    title:'Upcoming Ticklers Grouped'
    startTag:Tickler
    tags:'!Actioned'
    view:Tickler
    group:Contact
    gView:bold
    mode:global
    newButtonTags:'Tickler Enabled Once'
    where:'!tiddler.fields.mgtd_date || !tiddler.ticklerIsActive()'
    sort:'tickleDate'
    dontShowEmpty:yes
    ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>


}}}

}}}
<<ticklerAlert>>
<<mgtdList
	title:'Ticklers Requiring Action'
	startTag:Tickler
	tags:'!Actioned'
	view:Tickler
	mode:global
	newButtonTags:'Tickler Enabled Once'
	where:'tiddler.ticklerIsActive()'
	sort:'tickleDate'
	dontShowEmpty:yes
	ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>
// for sorting tiddlers

merge(Tiddler.prototype,{

	sort_tickleDate: function() {
		return this.fields['mgtd_date'] || 'ZZZZZZZZ'; // i think that's enought to make undated tiddlers sort to the end
	},

	sort_orderSlice: function() {
		var orderSlice = store.getTiddlerSlice(this.title,"order");
		return orderSlice ? orderSlice : this.title; // so if there's no slice we get sorting by title
	},

	sort_prioritySlice: function() {
		var orderSlice = store.getTiddlerSlice(this.title,"priority");
		return orderSlice ? orderSlice : this.title; // so if there's no slice we get sorting by title
	}

});
// for displaying tiddlers in lists

// idea: use <<tiddler with:?>>


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

config.mGTD.data = {
	starOn:    '',
	starOff:   '',

	unicodeStar: "\u2605" // "black star"
};


merge(Tiddler.prototype,{

	render_Action: function() { return this.renderUtil(
		'{{action{'+
		'<<toggleTag Done [[%0]] ->>'+
		'<<multiToggleTag tag:ActionStatus title:[[%0]]>>'+
		//'<<multiSelectTag tag:Project title:[[%0]]>>'+
		//'<<multiCheckboxTag tag:ActionStatus title:[[%0]]>>'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		' &nbsp;[[%0]] '+
		'<<deleteTiddler [[%0]]>>'+
		'}}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
		[
			this.title
		]
	);},

	render_Tickler: function() {
        var repeatType = this.getByIndex('TicklerRepeatType');
        var doneControl = "";
        if (repeatType.length == 0 || repeatType.contains('Once')) {
            // show normal done checkbox
            doneControl = '<<toggleTag Actioned [[%0]] ->>';
        }
        else if (repeatType.contains('Daily'))   { doneControl = '<<addDay [[%0]]>>' }
        else if (repeatType.contains('Weekly'))  { doneControl = '<<addWeek [[%0]]>>' }
        else if (repeatType.contains('Monthly')) { doneControl = '<<addMonth [[%0]]>>' }
        else if (repeatType.contains('Yearly'))  { doneControl = '<<addYear [[%0]]>>' }

        return this.renderUtil(
		'{{tickler{'+
        '%1'+  
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		'<<dateChooser [[%0]]>>'+
		'&nbsp;[[%0]]'+
		'<<deleteTiddler [[%0]]>>'+
		'}}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
		[
			this.title,
            doneControl.format([this.title])
		]
	);},

	render_Project: function() { return this.renderUtil(
		'{{project{'+
		'<<toggleTag Complete [[%0]] ->>'+
		'<<multiToggleTag tag:ProjectStatus title:[[%0]]>>'+
		//'<<multiSelectTag tag:Project title:[[%0]]>>'+
		//'<<multiCheckboxTag tag:ActionStatus title:[[%0]]>>'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		' &nbsp;[[%0]] }}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}'+
		"{{projLink{<<linkToParent Project '[P]' [[%0]]>>}}}"+
		"{{projLink{<<linkToParent Contact '[C]' [[%0]]>>}}}"+
		"",
		[
			this.title
		]
	);},

	render_ProjectArea: function() {
		var aLink = "";
	    return this.renderUtil(
		'{{project{'+
		'<<toggleTag Complete [[%0]] ->>'+
		'<<multiToggleTag tag:ProjectStatus title:[[%0]]>>'+
		//'<<multiSelectTag tag:Project title:[[%0]]>>'+
		//'<<multiCheckboxTag tag:ActionStatus title:[[%0]]>>'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		' &nbsp;[[%0]] }}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}'+
		"{{projLink{<<linkToParent Area    '[A]' [[%0]]>>}}}"+
		"{{projLink{<<linkToParent Project '[P]' [[%0]]>>}}}"+
		"{{projLink{<<linkToParent Contact '[C]' [[%0]]>>}}}"+
		"",
		[
			this.title,
			aLink
		]
	);},


	render_ProjectBare: function() { return this.renderUtil(
		'{{project{'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		'&nbsp;[[%0]] }}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
		[
			this.title
		]
	);},

	render_ProjectComplete: function() { return this.renderUtil(
		'{{project{'+
		'<<toggleTag Complete [[%0]] ->>'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		'&nbsp;[[%0]] }}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
		[
			this.title
		]
	);},


	render_ActionProj: function() {

		// actually it's not going to be easy to have
		// an action in more than one project
		// but just in case....
		var pLink = "";
		if (config.mGTD.getOptChk('FullProjectInActionLists')) {
			pLink += "{{projLinkFull{<<linkToParent Project [[title]] [[%0]]>>}}}".format([this.title]);
		}
		else {
			pLink += "{{projLink{<<linkToParent Project '[P]' [[%0]]>>}}}".format([this.title]);
		}

		if (config.mGTD.getOptChk('FullContactInActionLists')) {
			pLink += "{{projLinkFull{<<linkToParent Contact [[title]] [[%0]]>>}}}".format([this.title]);
		}
		else {
			pLink += "{{projLink{<<linkToParent Contact '[C]' [[%0]]>>}}}".format([this.title]);
		}

		return this.renderUtil(
		'{{action{'+
		'<<toggleTag Done [[%0]] ->>'+
		'<<multiToggleTag tag:ActionStatus title:[[%0]]>>'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		' &nbsp;[[%0]]'+
		'<<deleteTiddler [[%0]]>>'+
		'}}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}'+
		' %1',
		[
			this.title,
			pLink
		]
	);},

	render_DoneAction: function() { return this.renderUtil(
		'{{action{'+
		'<<toggleTag Done [[%0]] ->>'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		' [[%0]] '+
		'<<deleteTiddler [[%0]]>>'+
		'}}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
		[
			this.title
		]
	);},

	render_ProjectHeading: function() { return this.renderUtil(
		'{{project{'+
		'[[%0]] '+
		'<<toggleTag Complete [[%0]] ->>'+
		'@@font-size:80%;<<multiToggleTag tag:ProjectStatus title:[[%0]]>>@@'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
 		'}}}',
		[
			this.title
		]
	);},

	render_Context: function() { return this.renderUtil(
		'[[%0]]',
		[
			this.title
		]
	);},

	render_plain: function() { return this.renderUtil(
		'{{plain{[[%0]]}}}',
		[
			this.title
		]
	);},

	render_star: function() { return this.renderUtil(
		'{{plain{'+
		'<<singleToggleTag tag:Starred title:[[%0]]>>'+
		'[[%0]]}}}'+
		'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
		[
			this.title
		]
	);},


	// TODO. this seems stupid
	render_bold: function() { return this.renderUtil(
		"[[%0]]",
		[
			this.title
		]
	);}


});


*All [[derl|derl Online Booking]] ones
*Any new journals on Self
*[[Health History]]
*Janet Jansen re. http://mail.google.com/mail/#inbox/12132cecae0b25b1
*Irene Jansen re. http://mail.google.com/mail/#inbox/122803168ffe8fc5
*cisv Post request for National Camp leader http://mail.google.com/mail/#inbox/1227839859539873
*cisv Set up shop@cisvottawa.ca to forward to Thoma; Check site for email listed
*Check fb (Jeff Radema, Jill Hamer-Wilson)
*L Fix glasses
*Record bloodwork appt (Sep 3)
*Shauna re. The Smart Girls at the Party
*Transfer work files from Dell
*jems Install EasyPHP on HP

Note:
*Download Gmail contacts
*... now, easier to export/import (can do that individually? try) or to list here and then recreate. Know that I didn't do that with list I brought from Gmail one time ...
*Work locally with gtd because almost always on laptop and it saves automatically/quickly. But then need to upload whenever I'm going to work elsewhere.

Janet's Notes 2009-03-12

*Get email for Luke's Cub Camp
*Derek re. Hockey Camp
*Girls re. camps
*Calendar: L Science & Tech 9:15-2 Mar 31

#OGHA Site Transfer
*Check password protection on ogha/register/port
*Check backup on portable disk vs. oghaOLD
*Check that PayPal payments are still automatically registered
*Check deleteMember.php in ogha/register vs. port
*register/paynow.html is a test of the direct payment button (I think)
*Delete extraneous files on server (e.g., schedule/error_log)
*Reinstate schedule/images? birthday plugin leftovers (used?)
*Check whether forum is right version (admin/plugins/forum)

#jems
*Reinstate main folder files (Drupal)
*Buy BeyondCompare?
*Look at civicRM for pwc
*PWC Scan photos
*What is phpgroupware?
*Tips: Beyond Compare, Bit Torrent instructions, AVG virus protection, CCleaner, FTP: CoffeeFree, cuteFTP, CoreFTPLite; Version Control: CollabNetSubversion; Utilities: Defrag ; FileFormatConverters, FileRenamerBasic; Browsers: Flock 1.0.8, Firefox 3.0 RC2; GalleryRemote 1.5 

*Ask Derek re. PortableVaultInstaller
!Project
<!--{{{-->
<div class="projectcontrols controls controlstint">
 <div style="float:right;" class="smaller">
  <span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
  <span macro="tag Project"></span><span macro="help Project"></span>
 </div>
 <div>
  <span macro="toggleTag Complete . -"></span>
  <span class='title' macro='view title'></span>
  <span macro="miniTag"></span>
  <span macro="linkToParent Area '[A]'"></span>
  <span macro="linkToParent Project '[P]'"></span>
  <span macro="singleToggleTag tag:Starred"></span>
  [[MonkeyGTDTheme##Subtitle]]
 </div>
 <div macro="hideWhenTagged Complete" style="padding-top:0.25em;padding-bottom:0.25em;">
  <span macro="multiToggleTag ProjectStatus longVersion:on"></span>
 </div>
 <div>
  <div class="floatright" macro="convertToFromTickler"><br/></div>
  <div class="floatright" macro="deleteAllTagged 'delete project' '' 'delete'"><br/></div>
  <div class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
  <div class="floatleft"><span class="label">Subproject of</span>:<br><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
  <div class="floatleft"><span class="label">Associated contact</span>:<br><span macro="multiSelectTag Contact allowNone:on"></span><span macro="linkToParent Contact"></span></div>
  <div class="clearboth"></div>
 </div>
</div>
<!--}}}-->

!Action
<!--{{{-->
<div class="actioncontrols controls controlstint">
 <div style="float:right;" class="smaller">
  <span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
  <span macro="tag Action"></span><span macro="help Action"></span>
 </div>
 <div>
  <span macro="toggleTag Done . -"></span>
  <span class='title' macro='view title'></span>
  <span macro="miniTag"></span>
  <span macro="linkToParent Project '[P]'"></span>
  <span macro="singleToggleTag tag:Starred"></span>
  [[MonkeyGTDTheme##Subtitle]]
 </div>
 <div macro="hideWhenTagged Done" style="padding-top:0.25em;padding-bottom:0.25em;">
  <span macro="multiToggleTag ActionStatus longVersion:on"></span>
 </div>
 <div macro="showWhen config.mGTD.getOptChk('MultipleContexts')">
  <span class="label">Context:</span><br/><span class="unboldLinks" macro="groupOfSingleToggleTags Context useCheckbox:yes"></span>
 </div>
 <div>
  <div class="floatright" macro="convertToFromTickler"><br/></div>
  <div class="floatright" macro="convertActionToSubProj"><br/></div>
  <div class="floatright" macro="convertActionToReference"><br/></div>
  <div class="floatleft" macro="else"><span class="label">Context:</span><br/><span macro="multiSelectTag Context allowNone:on"></span><span macro="linkToParent Context"></span></div>
  <div class="floatleft"><span class="label">Project:</span><br/><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
  <div macro="hideWhen tiddler.hasParent('Project')" class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
  <div class="floatleft">
   <span macro="hideWhenTaggedAny 'Waiting For' 'Done'" class="label">Associated contact:</span>
   <span macro="else" class="label">Delegated to/waiting on:</span><br>
   <span macro="multiSelectTag Contact allowNone:on"></span><span macro="linkToParent Contact"></span>
  </div>
  <br style="clear:left"/>
  <div class="floatleft">
    <span class="label">Depends on:</span><br/><span macro="multiSelectTag Action allowNone:on"></span><span macro="linkToParent Action"></span>
   <!-- fixme. broken in 2.4.1 but works in 2.4.3?: <span macro="newSavedTiddler title:'new dependent action' label:'+ dependent action' tag:{{'Action Future [['+config.macros.mgtdList.getRealm()+']] [['+tiddler.getParent('Context')+']] [['+tiddler.getParent('Project')+']] [['+tiddler.title +']]'}}"></span> -->
  </div>
  <div class="clearboth"></div>
 </div>
</div>
<!--}}}-->

!Tickler
<!--{{{-->
<div class="ticklercontrols controls controlstint">
 <div style="float:right;" class="smaller">
  <span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
  <span macro="tag Tickler"></span><span macro="help Tickler"></span>
 </div>
 <div>
  <span macro="showWhen tiddler.tags.contains('Once') || !tiddler.hasParent('TicklerRepeatType')">
   <span macro="toggleTag Actioned . -"></span>
  </span>
  <span macro="showWhenTagged 'Daily'"   ><span macro="addDay"></span></span>
  <span macro="showWhenTagged 'Weekly'"  ><span macro="addWeek"></span></span>
  <span macro="showWhenTagged 'Monthly'" ><span macro="addMonth"></span></span>
  <span macro="showWhenTagged 'Yearly'"  ><span macro="addYear"></span></span>
  <span class='title' macro='view title'></span>
  <span macro="linkToParent Area '[A]'"></span>
  <span macro="linkToParent Project '[P]'"></span>
  <span macro="singleToggleTag tag:Starred"></span>
  [[MonkeyGTDTheme##Subtitle]]
 </div>
 <div macro="hideWhenTagged Actioned" style="padding-top:0.25em;padding-bottom:0.25em;">
  <span macro="multiToggleTag TicklerRepeatType longVersion:on"></span>
 </div>
 <div>
  <div class="floatleft"><span class="label">Tickler date:</span><br/><span macro="dateChooser"></span></div>
  <div class="floatleft buttonsLikeLinks"><br>
   <span macro="addDay"></span>
   <span macro="addWeek"></span>
   <span macro="addMonth"></span>
   <span macro="addYear"></span>
  </div>
  <div class="clearboth"></div>
 </div>
 <div>
  <div class="floatright" macro="convertToFromTickler"><br/></div>
  <div class="floatleft"><span class="label">Project:</span><br/><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
  <div macro="hideWhen tiddler.hasParent('Project')" class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
  <div class="floatleft"><span class="label">Associated contact</span>:<br><span macro="multiSelectTag Contact allowNone:on"></span><span macro="linkToParent Contact"></span></div>
  <div class="clearboth"></div>
 </div>
</div>
<!--}}}-->

!View
<!--{{{-->
<div class="viewcontrols controls">
 <div>
  <span class='title' macro='view title'></span><span macro="help"></span>
 </div>
</div>
<!--}}}-->

!Context
<!--{{{-->
<div class="contextcontrols controls">
 <div style="float:right;" class="smaller">
  <span macro="tag Context"></span><span macro="help Context"></span>
 </div>
 <div>
  <span class='title' macro='view title'></span>
  <span macro="miniTag"></span>
  <span macro="singleToggleTag tag:Starred"></span>
 </div>
</div>
<!--}}}-->

!Area
<!--{{{-->
<div class="areacontrols controls">
 <div style="float:right;" class="smaller">
  <span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
  <span macro="tag Area"></span><span macro="help Area"></span>
 </div>
 <div>
  <span class='title' macro='view title'></span>
  <span macro="miniTag"></span>
  <span macro="singleToggleTag tag:Starred"></span>
 </div>
</div>
<!--}}}-->

!Realm
<!--{{{-->
<div class="realmcontrols controls">
 <div style="float:right;" class="smaller">
  <span macro="tag Realm"></span><span macro="help Realm"></span>
 </div>
 <div>
  <span class='title' macro='view title'></span>
 </div>
</div>
<!--}}}-->

!Reference
<!--{{{-->
<div class="referencecontrols controls controlstint">
 <div style="float:right;" class="smaller">
  <span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
  <span macro="tag Reference"></span><span macro="help Reference"></span>
 </div>
 <div>
  <span class='title' macro='view title'></span>
  <span macro="linkToParent Project '[P]'"></span>
  <span macro="singleToggleTag tag:Starred"></span>
  [[MonkeyGTDTheme##Subtitle]]
 </div>
 <div>
  <div class="floatleft"><span class="label">Project:</span><br><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
  <div macro="hideWhen tiddler.hasParent('Project')" class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
 </div>
 <div class="clearboth"></div>
 <div style="padding-top:1em;">
  Double click or click "edit" to edit. Use "new here" to make sub item.
 </div>
</div>
<!--}}}-->

!Contact
<!--{{{-->
<div class="contactcontrols controls">
 <div style="float:right;" class="smaller">
  <span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
  <span macro="tag Contact"></span><span macro="help Contact"></span>
 </div>
 <div>
  <span class='title' macro='view title'></span>
  <span macro="miniTag"></span>
  <span macro="singleToggleTag tag:Starred"></span>
  [[MonkeyGTDTheme##Subtitle]]
 </div>
</div>
<!--}}}-->

<div macro="showWhenTagged 'Project'">[[TitleButtons##Project]]</div>
<div macro="showWhenTagged 'Action'">[[TitleButtons##Action]]</div>
<div macro="showWhenTagged 'Tickler'">[[TitleButtons##Tickler]]</div>
<div macro="showWhenTagged 'View'">[[TitleButtons##View]]</div>
<div macro="showWhenTagged 'Context'">[[TitleButtons##Context]]</div>
<div macro="showWhenTagged 'Area'">[[TitleButtons##Area]]</div>
<div macro="showWhenTagged 'Realm'">[[TitleButtons##Realm]]</div>
<div macro="showWhenTagged 'Reference'">[[TitleButtons##Reference]]</div>
<div macro="showWhenTagged 'Contact'">[[TitleButtons##Contact]]</div>
// Created by Saq. Taken from tw.lewcid.org

config.macros.toggleSideBar={};

config.macros.toggleSideBar.settings={
         styleHide :  "#sidebar { display: none;}\n"+"#contentWrapper #displayArea { margin-right: 1em;}\n"+"",
         styleShow : " ",
         arrow1: "<<",
         arrow2: ">>"
         //arrow1: "«",
         //arrow2: "»"
};

config.macros.toggleSideBar.handler=function (place,macroName,params,wikifier,paramString,tiddler)
{
          var tooltip= params[1]||'toggle sidebar';
          var mode = (params[2] && params[2]=="hide")? "hide":"show";
          var arrow = (mode == "hide")? this.settings.arrow1:this.settings.arrow2;
          var label= (params[0]&&params[0]!='.')?params[0]+" "+arrow:arrow;
          var theBtn = createTiddlyButton(place,label,tooltip,this.onToggleSideBar,"button HideSideBarButton");
          if (mode == "hide")
             { 
             (document.getElementById("sidebar")).setAttribute("toggle","hide");
              setStylesheet(this.settings.styleHide,"ToggleSideBarStyles");
             }
};

config.macros.toggleSideBar.onToggleSideBar = function(){
          var sidebar = document.getElementById("sidebar");
          var settings = config.macros.toggleSideBar.settings;
          if (sidebar.getAttribute("toggle")=='hide')
             {
              setStylesheet(settings.styleShow,"ToggleSideBarStyles");
              sidebar.setAttribute("toggle","show");
              this.firstChild.data= (this.firstChild.data).replace(settings.arrow1,settings.arrow2);
              }
          else
              {    
               setStylesheet(settings.styleHide,"ToggleSideBarStyles");
               sidebar.setAttribute("toggle","hide");
               this.firstChild.data= (this.firstChild.data).replace(settings.arrow2,settings.arrow1);
              }

     return false;
}

/***
|Name:|ToggleTagPlugin|
|Description:|Makes a checkbox which toggles a tag in a tiddler|
|Version:|3.1.0 ($Rev: 4907 $)|
|Date:|$Date: 2008-05-13 03:15:46 +1000 (Tue, 13 May 2008) $|
|Source:|http://mptw.tiddlyspot.com/#ToggleTagPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Usage
{{{<<toggleTag }}}//{{{TagName TiddlerName LabelText}}}//{{{>>}}}
* TagName - the tag to be toggled, default value "checked"
* TiddlerName - the tiddler to toggle the tag in, default value the current tiddler
* LabelText - the text (gets wikified) to put next to the check box, default value is '{{{[[TagName]]}}}' or '{{{[[TagName]] [[TiddlerName]]}}}'
(If a parameter is '.' then the default will be used)
* TouchMod flag - if non empty then touch the tiddlers mod date. Note, can set config.toggleTagAlwaysTouchModDate to always touch mod date
!!Examples
|Code|Description|Example|h
|{{{<<toggleTag>>}}}|Toggles the default tag (checked) in this tiddler|<<toggleTag>>|
|{{{<<toggleTag TagName>>}}}|Toggles the TagName tag in this tiddler|<<toggleTag TagName>>|
|{{{<<toggleTag TagName TiddlerName>>}}}|Toggles the TagName tag in the TiddlerName tiddler|<<toggleTag TagName TiddlerName>>|
|{{{<<toggleTag TagName TiddlerName 'click me'>>}}}|Same but with custom label|<<toggleTag TagName TiddlerName 'click me'>>|
|{{{<<toggleTag . . 'click me'>>}}}|dot means use default value|<<toggleTag . . 'click me'>>|
!!Notes
* If TiddlerName doesn't exist it will be silently created
* Set label to '-' to specify no label
* See also http://mgtd-alpha.tiddlyspot.com/#ToggleTag2
!!Known issues
* Doesn't smoothly handle the case where you toggle a tag in a tiddler that is current open for editing
* Should convert to use named params
***/
//{{{

if (config.toggleTagAlwaysTouchModDate == undefined) config.toggleTagAlwaysTouchModDate = false;

merge(config.macros,{

	toggleTag: {

		createIfRequired: true,
		shortLabel: "[[%0]]",
		longLabel: "[[%0]] [[%1]]",

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			var tiddlerTitle = tiddler ? tiddler.title : '';
			var tag   = (params[0] && params[0] != '.') ? params[0] : "checked";
			var title = (params[1] && params[1] != '.') ? params[1] : tiddlerTitle;
			var defaultLabel = (title == tiddlerTitle ? this.shortLabel : this.longLabel);
			var label = (params[2] && params[2] != '.') ? params[2] : defaultLabel;
			var touchMod = (params[3] && params[3] != '.') ? params[3] : "";
			label = (label == '-' ? '' : label); // dash means no label
			var theTiddler = (title == tiddlerTitle ? tiddler : store.getTiddler(title));
			var cb = createTiddlyCheckbox(place, label.format([tag,title]), theTiddler && theTiddler.isTagged(tag), function(e) {
				if (!store.tiddlerExists(title)) {
					if (config.macros.toggleTag.createIfRequired) {
						var content = store.getTiddlerText(title); // just in case it's a shadow
						store.saveTiddler(title,title,content?content:"",config.options.txtUserName,new Date(),null);
					}
					else 
						return false;
				}
				if ((touchMod != "" || config.toggleTagAlwaysTouchModDate) && theTiddler)
						theTiddler.modified = new Date();
				store.setTiddlerTag(title,this.checked,tag);
				return true;
			});
		}
	}
});

//}}}


*jems2004: domainsatcost.ca http://mail.google.com/mail/?shva=1#inbox/11b0887b6d2f89d2
OR
*bluehost: login.bluehost.com (YES!)
Big fight with OnlineNIC, but we won!
--[[OnlineNIC| http://mail.google.com/mail/#inbox/121a3fa159939591]] re. ottawagirlshockey.com (1-510-769-8492)--
#PayPal button encryption
**So people don't copy the button code and pay a different amount from elsewhere. This is really only a problem for non-customized systems that ship products automatically (we'd never complain if people paid again), but PayPal requires buttons to be encrypted for high-volume sites.
Select ALL Program Name to see just that program
Run register/port/updatePlayerExperience.php to set experience in jj_player to OGHA and increment #years



order:2
button:w
buttonLong:waiting for

Well, here we are again. Still trying to organize my life so I can get some sense of control. This week has been really awful. I have massive PMS complete with emotional swings, ANGER, and chocolate.

Need to finish Work [[OGHA Online Payment]] Clinics and Tryout registration, but am stuck with Online Payment. Need to move forward on this if only by entering my own.
order:2
button:week
buttonLong:weekly
There are quite a few people in the members list that registered last season, but withdrew and never played with us, I'd like to remove them out of our system so as to make the lists more manageable and the pages more accurate - how can I remove them entirely?

ANSWER: As mentioned in the earlier message, the system keeps all information. I can filter the lists so that withdrawn players don't show up in the members list. The players would be in the registration list and could be filtered out using Registered or Waiting List.

*Joanne Karakasis; Leah Petepiece
##Copy uid to old member
##Delete family, member, family_assignment
order:4
button:year
buttonLong:yearly
/***
|''Name:''|YourSearchPlugin|
|''Version:''|2.1.3 (2008-04-16)|
|''Source:''|http://tiddlywiki.abego-software.de/#YourSearchPlugin|
|''Author:''|UdoBorkowski (ub [at] abego-software [dot] de)|
|''Licence:''|[[BSD open source license (abego Software)|http://www.abego-software.de/legal/apl-v10.html]]|
|''Copyright:''|&copy; 2005-2008 [[abego Software|http://www.abego-software.de]]|
|''~CoreVersion:''|2.1.0|
|''Community:''|[[del.icio.us|http://del.icio.us/post?url=http://tiddlywiki.abego-software.de/index.html%23YourSearchPlugin]]|
|''Browser:''|Firefox 1.0.4+; Firefox 1.5; ~InternetExplorer 6.0|
!About YourSearch
YourSearch gives you a bunch of new features to simplify and speed up your daily searches in TiddlyWiki. It seamlessly integrates into the standard TiddlyWiki search: just start typing into the 'search' field and explore!

For more information see [[Help|YourSearch Help]].
!Compatibility
This plugin requires TiddlyWiki 2.1. 
Check the [[archive|http://tiddlywiki.abego-software.de/archive]] for ~YourSearchPlugins supporting older versions of TiddlyWiki.
!Source Code
***/
/***
This plugin's source code is compressed (and hidden). Use this [[link|http://tiddlywiki.abego-software.de/archive/YourSearchPlugin/Plugin-YourSearch-src.2.1.3.js]] to get the readable source code.
***/
///%
if(!version.extensions.YourSearchPlugin){version.extensions.YourSearchPlugin={major:2,minor:1,revision:3,source:"http://tiddlywiki.abego-software.de/#YourSearchPlugin",licence:"[[BSD open source license (abego Software)|http://www.abego-software.de/legal/apl-v10.html]]",copyright:"Copyright (c) abego Software GmbH, 2005-2008 (www.abego-software.de)"};if(!window.abego){window.abego={};}
if(!Array.forEach){Array.forEach=function(_1,_2,_3){for(var i=0,len=_1.length;i<len;i++){_2.call(_3,_1[i],i,_1);}};Array.prototype.forEach=function(_5,_6){for(var i=0,len=this.length;i<len;i++){_5.call(_6,this[i],i,this);}};}
abego.toInt=function(s,_9){if(!s){return _9;}
var n=parseInt(s);return(n==NaN)?_9:n;};abego.createEllipsis=function(_b){var e=createTiddlyElement(_b,"span");e.innerHTML="&hellip;";};abego.shallowCopy=function(_d){if(!_d){return _d;}
var _e={};for(var n in _d){_e[n]=_d[n];}
return _e;};abego.copyOptions=function(_10){return!_10?{}:abego.shallowCopy(_10);};abego.countStrings=function(_11,s){if(!s){return 0;}
var len=s.length;var n=0;var _15=0;while(1){var i=_11.indexOf(s,_15);if(i<0){return n;}
n++;_15=i+len;}
return n;};abego.getBracedText=function(_17,_18,_19){if(!_18){_18=0;}
var re=/\{([^\}]*)\}/gm;re.lastIndex=_18;var m=re.exec(_17);if(m){var s=m[1];var _1d=abego.countStrings(s,"{");if(!_1d){if(_19){_19.lastIndex=re.lastIndex;}
return s;}
var len=_17.length;for(var i=re.lastIndex;i<len&&_1d;i++){var c=_17.charAt(i);if(c=="{"){_1d++;}else{if(c=="}"){_1d--;}}}
if(!_1d){if(_19){_19.lastIndex=i-1;}
return _17.substring(m.index+1,i-1);}}};abego.select=function(_21,_22,_23,_24){if(!_24){_24=[];}
_21.forEach(function(t){if(_22.call(_23,t)){_24.push(t);}});return _24;};abego.consumeEvent=function(e){if(e.stopPropagation){e.stopPropagation();}
if(e.preventDefault){e.preventDefault();}
e.cancelBubble=true;e.returnValue=true;};abego.TiddlerFilterTerm=function(_27,_28){if(!_28){_28={};}
var _29=_27;if(!_28.textIsRegExp){_29=_27.escapeRegExp();if(_28.fullWordMatch){_29="\\b"+_29+"\\b";}}
var _2a=new RegExp(_29,"m"+(_28.caseSensitive?"":"i"));this.tester=new abego.MultiFieldRegExpTester(_2a,_28.fields,_28.withExtendedFields);};abego.TiddlerFilterTerm.prototype.test=function(_2b){return this.tester.test(_2b);};abego.parseNewTiddlerCommandLine=function(s){var m=/(.*?)\.(?:\s+|$)([^#]*)(#.*)?/.exec(s);if(!m){m=/([^#]*)()(#.*)?/.exec(s);}
if(m){var r;if(m[3]){var s2=m[3].replace(/#/g,"");r=s2.parseParams("tag");}else{r=[[]];}
var _30=m[2]?m[2].trim():"";r.push({name:"text",value:_30});r[0].text=[_30];return{title:m[1].trim(),params:r};}else{return{title:s.trim(),params:[[]]};}};abego.parseTiddlerFilterTerm=function(_31,_32,_33){var re=/\s*(?:(?:\{([^\}]*)\})|(?:(=)|([#%!])|(?:(\w+)\s*\:(?!\/\/))|(?:(?:("(?:(?:\\")|[^"])+")|(?:\/((?:(?:\\\/)|[^\/])+)\/)|(\w+\:\/\/[^\s]+)|([^\s\)\-\"]+)))))/mg;var _35={"!":"title","%":"text","#":"tags"};var _36={};var _37;re.lastIndex=_32;while(1){var i=re.lastIndex;var m=re.exec(_31);if(!m||m.index!=i){throw"Word or String literal expected";}
if(m[1]){var _3a={};var _3b=abego.getBracedText(_31,0,_3a);if(!_3b){throw"Invalid {...} syntax";}
var f=Function("tiddler","return ("+_3b+");");return{func:f,lastIndex:_3a.lastIndex,markRE:null};}
if(m[2]){_37=true;}else{if(m[3]){_36[_35[m[3]]]=1;}else{if(m[4]){_36[m[4]]=1;}else{var _3d=m[6];var _3e=m[5]?window.eval(m[5]):m[6]?m[6]:m[7]?m[7]:m[8];var _33=abego.copyOptions(_33);_33.fullWordMatch=_37;_33.textIsRegExp=_3d;var _3f=[];for(var n in _36){_3f.push(n);}
if(_3f.length==0){_33.fields=_33.defaultFields;}else{_33.fields=_3f;_33.withExtendedFields=false;}
var _41=new abego.TiddlerFilterTerm(_3e,_33);var _42=_3d?_3e:_3e.escapeRegExp();if(_42&&_37){_42="\\b"+_42+"\\b";}
return{func:function(_43){return _41.test(_43);},lastIndex:re.lastIndex,markRE:_42?"(?:"+_42+")":null};}}}}};abego.BoolExp=function(s,_45,_46){this.s=s;var _47=_46&&_46.defaultOperationIs_OR;var _48=/\s*(?:(\-|not)|(\())/gi;var _49=/\s*\)/g;var _4a=/\s*(?:(and|\&\&)|(or|\|\|))/gi;var _4b=/\s*[^\)\s]/g;var _4c=/\s*(\-|not)?(\s*\()?/gi;var _4d;var _4e=function(_4f){_4c.lastIndex=_4f;var m=_4c.exec(s);var _51;var _52;if(m&&m.index==_4f){_4f+=m[0].length;_51=m[1];if(m[2]){var e=_4d(_4f);_49.lastIndex=e.lastIndex;if(!_49.exec(s)){throw"Missing ')'";}
_52={func:e.func,lastIndex:_49.lastIndex,markRE:e.markRE};}}
if(!_52){_52=_45(s,_4f,_46);}
if(_51){_52.func=(function(f){return function(_55){return!f(_55);};})(_52.func);_52.markRE=null;}
return _52;};_4d=function(_56){var _57=_4e(_56);while(1){var l=_57.lastIndex;_4a.lastIndex=l;var m=_4a.exec(s);var _5a;var _5b;if(m&&m.index==l){_5a=!m[1];_5b=_4e(_4a.lastIndex);}else{try{_5b=_4e(l);}
catch(e){return _57;}
_5a=_47;}
_57.func=(function(_5c,_5d,_5e){return _5e?function(_5f){return _5c(_5f)||_5d(_5f);}:function(_60){return _5c(_60)&&_5d(_60);};})(_57.func,_5b.func,_5a);_57.lastIndex=_5b.lastIndex;if(!_57.markRE){_57.markRE=_5b.markRE;}else{if(_5b.markRE){_57.markRE=_57.markRE+"|"+_5b.markRE;}}}};var _61=_4d(0);this.evalFunc=_61.func;if(_61.markRE){this.markRegExp=new RegExp(_61.markRE,_46.caseSensitive?"mg":"img");}};abego.BoolExp.prototype.exec=function(){return this.evalFunc.apply(this,arguments);};abego.BoolExp.prototype.getMarkRegExp=function(){return this.markRegExp;};abego.BoolExp.prototype.toString=function(){return this.s;};abego.MultiFieldRegExpTester=function(re,_63,_64){this.re=re;this.fields=_63?_63:["title","text","tags"];this.withExtendedFields=_64;};abego.MultiFieldRegExpTester.prototype.test=function(_65){var re=this.re;for(var i=0;i<this.fields.length;i++){var s=store.getValue(_65,this.fields[i]);if(typeof s=="string"&&re.test(s)){return this.fields[i];}}
if(this.withExtendedFields){return store.forEachField(_65,function(_69,_6a,_6b){return typeof _6b=="string"&&re.test(_6b)?_6a:null;},true);}
return null;};abego.TiddlerQuery=function(_6c,_6d,_6e,_6f,_70){if(_6e){this.regExp=new RegExp(_6c,_6d?"mg":"img");this.tester=new abego.MultiFieldRegExpTester(this.regExp,_6f,_70);}else{this.expr=new abego.BoolExp(_6c,abego.parseTiddlerFilterTerm,{defaultFields:_6f,caseSensitive:_6d,withExtendedFields:_70});}
this.getQueryText=function(){return _6c;};this.getUseRegExp=function(){return _6e;};this.getCaseSensitive=function(){return _6d;};this.getDefaultFields=function(){return _6f;};this.getWithExtendedFields=function(){return _70;};};abego.TiddlerQuery.prototype.test=function(_71){if(!_71){return false;}
if(this.regExp){return this.tester.test(_71);}
return this.expr.exec(_71);};abego.TiddlerQuery.prototype.filter=function(_72){return abego.select(_72,this.test,this);};abego.TiddlerQuery.prototype.getMarkRegExp=function(){if(this.regExp){return"".search(this.regExp)>=0?null:this.regExp;}
return this.expr.getMarkRegExp();};abego.TiddlerQuery.prototype.toString=function(){return(this.regExp?this.regExp:this.expr).toString();};abego.PageWiseRenderer=function(){this.firstIndexOnPage=0;};merge(abego.PageWiseRenderer.prototype,{setItems:function(_73){this.items=_73;this.setFirstIndexOnPage(0);},getMaxPagesInNavigation:function(){return 10;},getItemsCount:function(_74){return this.items?this.items.length:0;},getCurrentPageIndex:function(){return Math.floor(this.firstIndexOnPage/this.getItemsPerPage());},getLastPageIndex:function(){return Math.floor((this.getItemsCount()-1)/this.getItemsPerPage());},setFirstIndexOnPage:function(_75){this.firstIndexOnPage=Math.min(Math.max(0,_75),this.getItemsCount()-1);},getFirstIndexOnPage:function(){this.firstIndexOnPage=Math.floor(this.firstIndexOnPage/this.getItemsPerPage())*this.getItemsPerPage();return this.firstIndexOnPage;},getLastIndexOnPage:function(){return Math.min(this.getFirstIndexOnPage()+this.getItemsPerPage()-1,this.getItemsCount()-1);},onPageChanged:function(_76,_77){},renderPage:function(_78){if(_78.beginRendering){_78.beginRendering(this);}
try{if(this.getItemsCount()){var _79=this.getLastIndexOnPage();var _7a=-1;for(var i=this.getFirstIndexOnPage();i<=_79;i++){_7a++;_78.render(this,this.items[i],i,_7a);}}}
finally{if(_78.endRendering){_78.endRendering(this);}}},addPageNavigation:function(_7c){if(!this.getItemsCount()){return;}
var _7d=this;var _7e=function(e){if(!e){var e=window.event;}
abego.consumeEvent(e);var _80=abego.toInt(this.getAttribute("page"),0);var _81=_7d.getCurrentPageIndex();if(_80==_81){return;}
var _82=_80*_7d.getItemsPerPage();_7d.setFirstIndexOnPage(_82);_7d.onPageChanged(_80,_81);};var _83;var _84=this.getCurrentPageIndex();var _85=this.getLastPageIndex();if(_84>0){_83=createTiddlyButton(_7c,"Previous","Go to previous page (Shortcut: Alt-'<')",_7e,"prev");_83.setAttribute("page",(_84-1).toString());_83.setAttribute("accessKey","<");}
for(var i=-this.getMaxPagesInNavigation();i<this.getMaxPagesInNavigation();i++){var _87=_84+i;if(_87<0){continue;}
if(_87>_85){break;}
var _88=(i+_84+1).toString();var _89=_87==_84?"currentPage":"otherPage";_83=createTiddlyButton(_7c,_88,"Go to page %0".format([_88]),_7e,_89);_83.setAttribute("page",(_87).toString());}
if(_84<_85){_83=createTiddlyButton(_7c,"Next","Go to next page (Shortcut: Alt-'>')",_7e,"next");_83.setAttribute("page",(_84+1).toString());_83.setAttribute("accessKey",">");}}});abego.LimitedTextRenderer=function(){var _8a=40;var _8b=4;var _8c=function(_8d,_8e,_8f){var n=_8d.length;if(n==0){_8d.push({start:_8e,end:_8f});return;}
var i=0;for(;i<n;i++){var _92=_8d[i];if(_92.start<=_8f&&_8e<=_92.end){var r;var _94=i+1;for(;_94<n;_94++){r=_8d[_94];if(r.start>_8f||_8e>_92.end){break;}}
var _95=_8e;var _96=_8f;for(var j=i;j<_94;j++){r=_8d[j];_95=Math.min(_95,r.start);_96=Math.max(_96,r.end);}
_8d.splice(i,_94-i,{start:_95,end:_96});return;}
if(_92.start>_8f){break;}}
_8d.splice(i,0,{start:_8e,end:_8f});};var _98=function(_99){var _9a=0;for(var i=0;i<_99.length;i++){var _9c=_99[i];_9a+=_9c.end-_9c.start;}
return _9a;};var _9d=function(c){return(c>="a"&&c<="z")||(c>="A"&&c<="Z")||c=="_";};var _9f=function(s,_a1){if(!_9d(s[_a1])){return null;}
for(var i=_a1-1;i>=0&&_9d(s[i]);i--){}
var _a3=i+1;var n=s.length;for(i=_a1+1;i<n&&_9d(s[i]);i++){}
return{start:_a3,end:i};};var _a5=function(s,_a7,_a8){var _a9;if(_a8){_a9=_9f(s,_a7);}else{if(_a7<=0){return _a7;}
_a9=_9f(s,_a7-1);}
if(!_a9){return _a7;}
if(_a8){if(_a9.start>=_a7-_8b){return _a9.start;}
if(_a9.end<=_a7+_8b){return _a9.end;}}else{if(_a9.end<=_a7+_8b){return _a9.end;}
if(_a9.start>=_a7-_8b){return _a9.start;}}
return _a7;};var _aa=function(s,_ac){var _ad=[];if(_ac){var _ae=0;var n=s.length;var _b0=0;do{_ac.lastIndex=_ae;var _b1=_ac.exec(s);if(_b1){if(_ae<_b1.index){var t=s.substring(_ae,_b1.index);_ad.push({text:t});}
_ad.push({text:_b1[0],isMatch:true});_ae=_b1.index+_b1[0].length;}else{_ad.push({text:s.substr(_ae)});break;}}while(true);}else{_ad.push({text:s});}
return _ad;};var _b3=function(_b4){var _b5=0;for(var i=0;i<_b4.length;i++){if(_b4[i].isMatch){_b5++;}}
return _b5;};var _b7=function(s,_b9,_ba,_bb,_bc){var _bd=Math.max(Math.floor(_bc/(_bb+1)),_8a);var _be=Math.max(_bd-(_ba-_b9),0);var _bf=Math.min(Math.floor(_ba+_be/3),s.length);var _c0=Math.max(_bf-_bd,0);_c0=_a5(s,_c0,true);_bf=_a5(s,_bf,false);return{start:_c0,end:_bf};};var _c1=function(_c2,s,_c4){var _c5=[];var _c6=_b3(_c2);var pos=0;for(var i=0;i<_c2.length;i++){var t=_c2[i];var _ca=t.text;if(t.isMatch){var _cb=_b7(s,pos,pos+_ca.length,_c6,_c4);_8c(_c5,_cb.start,_cb.end);}
pos+=_ca.length;}
return _c5;};var _cc=function(s,_ce,_cf){var _d0=_cf-_98(_ce);while(_d0>0){if(_ce.length==0){_8c(_ce,0,_a5(s,_cf,false));return;}else{var _d1=_ce[0];var _d2;var _d3;if(_d1.start==0){_d2=_d1.end;if(_ce.length>1){_d3=_ce[1].start;}else{_8c(_ce,_d2,_a5(s,_d2+_d0,false));return;}}else{_d2=0;_d3=_d1.start;}
var _d4=Math.min(_d3,_d2+_d0);_8c(_ce,_d2,_d4);_d0-=(_d4-_d2);}}};var _d5=function(_d6,s,_d8,_d9,_da){if(_d9.length==0){return;}
var _db=function(_dc,s,_de,_df,_e0){var t;var _e2;var pos=0;var i=0;var _e5=0;for(;i<_de.length;i++){t=_de[i];_e2=t.text;if(_df<pos+_e2.length){_e5=_df-pos;break;}
pos+=_e2.length;}
var _e6=_e0-_df;for(;i<_de.length&&_e6>0;i++){t=_de[i];_e2=t.text.substr(_e5);_e5=0;if(_e2.length>_e6){_e2=_e2.substr(0,_e6);}
if(t.isMatch){createTiddlyElement(_dc,"span",null,"marked",_e2);}else{createTiddlyText(_dc,_e2);}
_e6-=_e2.length;}
if(_e0<s.length){abego.createEllipsis(_dc);}};if(_d9[0].start>0){abego.createEllipsis(_d6);}
var _e7=_da;for(var i=0;i<_d9.length&&_e7>0;i++){var _e9=_d9[i];var len=Math.min(_e9.end-_e9.start,_e7);_db(_d6,s,_d8,_e9.start,_e9.start+len);_e7-=len;}};this.render=function(_eb,s,_ed,_ee){if(s.length<_ed){_ed=s.length;}
var _ef=_aa(s,_ee);var _f0=_c1(_ef,s,_ed);_cc(s,_f0,_ed);_d5(_eb,s,_ef,_f0,_ed);};};(function(){function alertAndThrow(msg){alert(msg);throw msg;}
if(version.major<2||(version.major==2&&version.minor<1)){alertAndThrow("YourSearchPlugin requires TiddlyWiki 2.1 or newer.\n\nCheck the archive for YourSearch plugins\nsupporting older versions of TiddlyWiki.\n\nArchive: http://tiddlywiki.abego-software.de/archive");}
abego.YourSearch={};var _f2;var _f3;var _f4=function(_f5){_f2=_f5;};var _f6=function(){return _f2?_f2:[];};var _f7=function(){return _f2?_f2.length:0;};var _f8=4;var _f9=10;var _fa=2;var _fb=function(s,re){var m=s.match(re);return m?m.length:0;};var _ff=function(_100,_101){var _102=_101.getMarkRegExp();if(!_102){return 1;}
var _103=_100.title.match(_102);var _104=_103?_103.length:0;var _105=_fb(_100.getTags(),_102);var _106=_103?_103.join("").length:0;var _107=_100.title.length>0?_106/_100.title.length:0;var rank=_104*_f8+_105*_fa+_107*_f9+1;return rank;};var _109=function(_10a,_10b,_10c,_10d,_10e,_10f){_f3=null;var _110=_10a.reverseLookup("tags",_10f,false);try{var _111=[];if(config.options.chkSearchInTitle){_111.push("title");}
if(config.options.chkSearchInText){_111.push("text");}
if(config.options.chkSearchInTags){_111.push("tags");}
_f3=new abego.TiddlerQuery(_10b,_10c,_10d,_111,config.options.chkSearchExtendedFields);}
catch(e){return[];}
var _112=_f3.filter(_110);var _113=abego.YourSearch.getRankFunction();for(var i=0;i<_112.length;i++){var _115=_112[i];var rank=_113(_115,_f3);_115.searchRank=rank;}
if(!_10e){_10e="title";}
var _117=function(a,b){var _11a=a.searchRank-b.searchRank;if(_11a==0){if(a[_10e]==b[_10e]){return(0);}else{return(a[_10e]<b[_10e])?-1:+1;}}else{return(_11a>0)?-1:+1;}};_112.sort(_117);return _112;};var _11b=80;var _11c=50;var _11d=250;var _11e=50;var _11f=25;var _120=10;var _121="yourSearchResult";var _122="yourSearchResultItems";var _123;var _124;var _125;var _126;var _127;var _128=function(){if(version.extensions.YourSearchPlugin.styleSheetInited){return;}
version.extensions.YourSearchPlugin.styleSheetInited=true;setStylesheet(store.getTiddlerText("YourSearchStyleSheet"),"yourSearch");};var _129=function(){return _124!=null&&_124.parentNode==document.body;};var _12a=function(){if(_129()){document.body.removeChild(_124);}};var _12b=function(e){_12a();var _12d=this.getAttribute("tiddlyLink");if(_12d){var _12e=this.getAttribute("withHilite");var _12f=highlightHack;if(_12e&&_12e=="true"&&_f3){highlightHack=_f3.getMarkRegExp();}
story.displayTiddler(this,_12d);highlightHack=_12f;}
return(false);};var _130=function(){if(!_125){return;}
var root=_125;var _132=findPosX(root);var _133=findPosY(root);var _134=root.offsetHeight;var _135=_132;var _136=_133+_134;var _137=findWindowWidth();if(_137<_124.offsetWidth){_124.style.width=(_137-100)+"px";_137=findWindowWidth();}
var _138=_124.offsetWidth;if(_135+_138>_137){_135=_137-_138-30;}
if(_135<0){_135=0;}
_124.style.left=_135+"px";_124.style.top=_136+"px";_124.style.display="block";};var _139=function(){if(_124){window.scrollTo(0,ensureVisible(_124));}
if(_125){window.scrollTo(0,ensureVisible(_125));}};var _13a=function(){_130();_139();};var _13b;var _13c;var _13d=new abego.PageWiseRenderer();var _13e=function(_13f){this.itemHtml=store.getTiddlerText("YourSearchItemTemplate");if(!this.itemHtml){alertAndThrow("YourSearchItemTemplate not found");}
this.place=document.getElementById(_122);if(!this.place){this.place=createTiddlyElement(_13f,"div",_122);}};merge(_13e.prototype,{render:function(_140,_141,_142,_143){_13b=_143;_13c=_141;var item=createTiddlyElement(this.place,"div",null,"yourSearchItem");item.innerHTML=this.itemHtml;applyHtmlMacros(item,null);refreshElements(item,null);},endRendering:function(_145){_13c=null;}});var _146=function(){if(!_124||!_125){return;}
var html=store.getTiddlerText("YourSearchResultTemplate");if(!html){html="<b>Tiddler YourSearchResultTemplate not found</b>";}
_124.innerHTML=html;applyHtmlMacros(_124,null);refreshElements(_124,null);var _148=new _13e(_124);_13d.renderPage(_148);_13a();};_13d.getItemsPerPage=function(){var n=(config.options.chkPreviewText)?abego.toInt(config.options.txtItemsPerPageWithPreview,_120):abego.toInt(config.options.txtItemsPerPage,_11f);return(n>0)?n:1;};_13d.onPageChanged=function(){_146();};var _14a=function(){if(_125==null||!config.options.chkUseYourSearch){return;}
if((_125.value==_123)&&_123&&!_129()){if(_124&&(_124.parentNode!=document.body)){document.body.appendChild(_124);_13a();}else{abego.YourSearch.onShowResult(true);}}};var _14b=function(){_12a();_124=null;_123=null;};var _14c=function(self,e){while(e!=null){if(self==e){return true;}
e=e.parentNode;}
return false;};var _14f=function(e){if(e.target==_125){return;}
if(e.target==_126){return;}
if(_124&&_14c(_124,e.target)){return;}
_12a();};var _151=function(e){if(e.keyCode==27){_12a();}};addEvent(document,"click",_14f);addEvent(document,"keyup",_151);var _153=function(text,_155,_156){_123=text;_f4(_109(store,text,_155,_156,"title","excludeSearch"));abego.YourSearch.onShowResult();};var _157=function(_158,_159,_15a,_15b,_15c,_15d){_128();_123="";var _15e=null;var _15f=function(txt){if(config.options.chkUseYourSearch){_153(txt.value,config.options.chkCaseSensitiveSearch,config.options.chkRegExpSearch);}else{story.search(txt.value,config.options.chkCaseSensitiveSearch,config.options.chkRegExpSearch);}
_123=txt.value;};var _161=function(e){_15f(_125);return false;};var _163=function(e){if(!e){var e=window.event;}
_125=this;switch(e.keyCode){case 13:if(e.ctrlKey&&_127&&_129()){_127.onclick.apply(_127,[e]);}else{_15f(this);}
break;case 27:if(_129()){_12a();}else{this.value="";clearMessage();}
break;}
if(String.fromCharCode(e.keyCode)==this.accessKey||e.altKey){_14a();}
if(this.value.length<3&&_15e){clearTimeout(_15e);}
if(this.value.length>2){if(this.value!=_123){if(!config.options.chkUseYourSearch||config.options.chkSearchAsYouType){if(_15e){clearTimeout(_15e);}
var txt=this;_15e=setTimeout(function(){_15f(txt);},500);}}else{if(_15e){clearTimeout(_15e);}}}
if(this.value.length==0){_12a();}};var _166=function(e){this.select();clearMessage();_14a();};var args=_15c.parseParams("list",null,true);var _169=getFlag(args,"buttonAtRight");var _16a=getParam(args,"sizeTextbox",this.sizeTextbox);var btn;if(!_169){btn=createTiddlyButton(_158,this.label,this.prompt,_161);}
var txt=createTiddlyElement(_158,"input",null,null,null);if(_15a[0]){txt.value=_15a[0];}
txt.onkeyup=_163;txt.onfocus=_166;txt.setAttribute("size",_16a);txt.setAttribute("accessKey",this.accessKey);txt.setAttribute("autocomplete","off");if(config.browser.isSafari){txt.setAttribute("type","search");txt.setAttribute("results","5");}else{txt.setAttribute("type","text");}
if(_169){btn=createTiddlyButton(_158,this.label,this.prompt,_161);}
_125=txt;_126=btn;};var _16d=function(){_12a();var _16e=_f6();var n=_16e.length;if(n){var _170=[];for(var i=0;i<n;i++){_170.push(_16e[i].title);}
story.displayTiddlers(null,_170);}};var _172=function(_173,_174,_175,_176){invokeMacro(_173,"option",_174,_175,_176);var elem=_173.lastChild;var _178=elem.onclick;elem.onclick=function(e){var _17a=_178.apply(this,arguments);_146();return _17a;};return elem;};var _17b=function(s){var _17d=["''","{{{","}}}","//","<<<","/***","***/"];var _17e="";for(var i=0;i<_17d.length;i++){if(i!=0){_17e+="|";}
_17e+="("+_17d[i].escapeRegExp()+")";}
return s.replace(new RegExp(_17e,"mg"),"").trim();};var _180=function(){var i=_13b;return(i>=0&&i<=9)?(i<9?(i+1):0):-1;};var _182=new abego.LimitedTextRenderer();var _183=function(_184,s,_186){_182.render(_184,s,_186,_f3.getMarkRegExp());};var _187=TiddlyWiki.prototype.saveTiddler;TiddlyWiki.prototype.saveTiddler=function(_188,_189,_18a,_18b,_18c,tags,_18e){_187.apply(this,arguments);_14b();};var _18f=TiddlyWiki.prototype.removeTiddler;TiddlyWiki.prototype.removeTiddler=function(_190){_18f.apply(this,arguments);_14b();};config.macros.yourSearch={label:"yourSearch",prompt:"Gives access to the current/last YourSearch result",handler:function(_191,_192,_193,_194,_195,_196){if(_193.length==0){return;}
var name=_193[0];var func=config.macros.yourSearch.funcs[name];if(func){func(_191,_192,_193,_194,_195,_196);}},tests:{"true":function(){return true;},"false":function(){return false;},"found":function(){return _f7()>0;},"previewText":function(){return config.options.chkPreviewText;}},funcs:{itemRange:function(_199){if(_f7()){var _19a=_13d.getLastIndexOnPage();var s="%0 - %1".format([_13d.getFirstIndexOnPage()+1,_19a+1]);createTiddlyText(_199,s);}},count:function(_19c){createTiddlyText(_19c,_f7().toString());},query:function(_19d){if(_f3){createTiddlyText(_19d,_f3.toString());}},version:function(_19e){var t="YourSearch %0.%1.%2".format([version.extensions.YourSearchPlugin.major,version.extensions.YourSearchPlugin.minor,version.extensions.YourSearchPlugin.revision]);var e=createTiddlyElement(_19e,"a");e.setAttribute("href","http://tiddlywiki.abego-software.de/#YourSearchPlugin");e.innerHTML="<font color=\"black\" face=\"Arial, Helvetica, sans-serif\">"+t+"<font>";},copyright:function(_1a1){var e=createTiddlyElement(_1a1,"a");e.setAttribute("href","http://www.abego-software.de");e.innerHTML="<font color=\"black\" face=\"Arial, Helvetica, sans-serif\">&copy; 2005-2008 <b><font color=\"red\">abego</font></b> Software<font>";},newTiddlerButton:function(_1a3){if(_f3){var r=abego.parseNewTiddlerCommandLine(_f3.getQueryText());var btn=config.macros.newTiddler.createNewTiddlerButton(_1a3,r.title,r.params,"new tiddler","Create a new tiddler based on search text. (Shortcut: Ctrl-Enter; Separators: '.', '#')",null,"text");var _1a6=btn.onclick;btn.onclick=function(){_12a();_1a6.apply(this,arguments);};_127=btn;}},linkButton:function(_1a7,_1a8,_1a9,_1aa,_1ab,_1ac){if(_1a9<2){return;}
var _1ad=_1a9[1];var text=_1a9<3?_1ad:_1a9[2];var _1af=_1a9<4?text:_1a9[3];var _1b0=_1a9<5?null:_1a9[4];var btn=createTiddlyButton(_1a7,text,_1af,_12b,null,null,_1b0);btn.setAttribute("tiddlyLink",_1ad);},closeButton:function(_1b2,_1b3,_1b4,_1b5,_1b6,_1b7){var _1b8=createTiddlyButton(_1b2,"close","Close the Search Results (Shortcut: ESC)",_12a);},openAllButton:function(_1b9,_1ba,_1bb,_1bc,_1bd,_1be){var n=_f7();if(n==0){return;}
var _1c0=n==1?"open tiddler":"open all %0 tiddlers".format([n]);var _1c1=createTiddlyButton(_1b9,_1c0,"Open all found tiddlers (Shortcut: Alt-O)",_16d);_1c1.setAttribute("accessKey","O");},naviBar:function(_1c2,_1c3,_1c4,_1c5,_1c6,_1c7){_13d.addPageNavigation(_1c2);},"if":function(_1c8,_1c9,_1ca,_1cb,_1cc,_1cd){if(_1ca.length<2){return;}
var _1ce=_1ca[1];var _1cf=(_1ce=="not");if(_1cf){if(_1ca.length<3){return;}
_1ce=_1ca[2];}
var test=config.macros.yourSearch.tests[_1ce];var _1d1=false;try{if(test){_1d1=test(_1c8,_1c9,_1ca,_1cb,_1cc,_1cd)!=_1cf;}else{_1d1=(!eval(_1ce))==_1cf;}}
catch(ex){}
if(!_1d1){_1c8.style.display="none";}},chkPreviewText:function(_1d2,_1d3,_1d4,_1d5,_1d6,_1d7){var _1d8=_1d4.slice(1).join(" ");var elem=_172(_1d2,"chkPreviewText",_1d5,_1d7);elem.setAttribute("accessKey","P");elem.title="Show text preview of found tiddlers (Shortcut: Alt-P)";return elem;}}};config.macros.foundTiddler={label:"foundTiddler",prompt:"Provides information on the tiddler currently processed on the YourSearch result page",handler:function(_1da,_1db,_1dc,_1dd,_1de,_1df){var name=_1dc[0];var func=config.macros.foundTiddler.funcs[name];if(func){func(_1da,_1db,_1dc,_1dd,_1de,_1df);}},funcs:{title:function(_1e2,_1e3,_1e4,_1e5,_1e6,_1e7){if(!_13c){return;}
var _1e8=_180();var _1e9=_1e8>=0?"Open tiddler (Shortcut: Alt-%0)".format([_1e8.toString()]):"Open tiddler";var btn=createTiddlyButton(_1e2,null,_1e9,_12b,null);btn.setAttribute("tiddlyLink",_13c.title);btn.setAttribute("withHilite","true");_183(btn,_13c.title,_11b);if(_1e8>=0){btn.setAttribute("accessKey",_1e8.toString());}},tags:function(_1eb,_1ec,_1ed,_1ee,_1ef,_1f0){if(!_13c){return;}
_183(_1eb,_13c.getTags(),_11c);},text:function(_1f1,_1f2,_1f3,_1f4,_1f5,_1f6){if(!_13c){return;}
_183(_1f1,_17b(_13c.text),_11d);},field:function(_1f7,_1f8,_1f9,_1fa,_1fb,_1fc){if(!_13c){return;}
var name=_1f9[1];var len=_1f9.length>2?abego.toInt(_1f9[2],_11e):_11e;var v=store.getValue(_13c,name);if(v){_183(_1f7,_17b(v),len);}},number:function(_200,_201,_202,_203,_204,_205){var _206=_180();if(_206>=0){var text="%0)".format([_206.toString()]);createTiddlyElement(_200,"span",null,"shortcutNumber",text);}}}};var opts={chkUseYourSearch:true,chkPreviewText:true,chkSearchAsYouType:true,chkSearchInTitle:true,chkSearchInText:true,chkSearchInTags:true,chkSearchExtendedFields:true,txtItemsPerPage:_11f,txtItemsPerPageWithPreview:_120};for(var n in opts){if(config.options[n]==undefined){config.options[n]=opts[n];}}
config.shadowTiddlers.AdvancedOptions+="\n<<option chkUseYourSearch>> Use 'Your Search' //([[more options|YourSearch Options]]) ([[help|YourSearch Help]])// ";config.shadowTiddlers["YourSearch Help"]="!Field Search\nWith the Field Search you can restrict your search to certain fields of a tiddler, e.g"+" only search the tags or only the titles. The general form is //fieldname//'':''//textToSearch// (e."+"g. {{{title:intro}}}). In addition one-character shortcuts are also supported for the standard field"+"s {{{title}}}, {{{text}}} and {{{tags}}}:\n|!What you want|!What you type|!Example|\n|Search ''titles "+"only''|start word with ''!''|{{{!jonny}}} (shortcut for {{{title:jonny}}})|\n|Search ''contents/text "+"only''|start word with ''%''|{{{%football}}} (shortcut for {{{text:football}}})|\n|Search ''tags only"+"''|start word with ''#''|{{{#Plugin}}} (shortcut for {{{tags:Plugin}}})|\n\nUsing this feature you may"+" also search the extended fields (\"Metadata\") introduced with TiddlyWiki 2.1, e.g. use {{{priority:1"+"}}} to find all tiddlers with the priority field set to \"1\".\n\nYou may search a word in more than one"+" field. E.g. {{{!#Plugin}}} (or {{{title:tags:Plugin}}} in the \"long form\") finds tiddlers containin"+"g \"Plugin\" either in the title or in the tags (but does not look for \"Plugin\" in the text). \n\n!Boole"+"an Search\nThe Boolean Search is useful when searching for multiple words.\n|!What you want|!What you "+"type|!Example|\n|''All words'' must exist|List of words|{{{jonny jeremy}}} (or {{{jonny and jeremy}}}"+")|\n|''At least one word'' must exist|Separate words by ''or''|{{{jonny or jeremy}}}|\n|A word ''must "+"not exist''|Start word with ''-''|{{{-jonny}}} (or {{{not jonny}}})|\n\n''Note:'' When you specify two"+" words, separated with a space, YourSearch finds all tiddlers that contain both words, but not neces"+"sarily next to each other. If you want to find a sequence of word, e.g. '{{{John Brown}}}', you need"+" to put the words into quotes. I.e. you type: {{{\"john brown\"}}}.\n\nUsing parenthesis you may change "+"the default \"left to right\" evaluation of the boolean search. E.g. {{{not (jonny or jeremy)}}} finds"+" all tiddlers that contain neither \"jonny\" nor \"jeremy. In contrast to this {{{not jonny or jeremy}}"+"} (i.e. without parenthesis) finds all tiddlers that either don't contain \"jonny\" or that contain \"j"+"eremy\".\n\n!'Exact Word' Search\nBy default a search result all matches that 'contain' the searched tex"+"t. E.g. if you search for {{{Task}}} you will get all tiddlers containing 'Task', but also '~Complet"+"edTask', '~TaskForce' etc.\n\nIf you only want to get the tiddlers that contain 'exactly the word' you"+" need to prefix it with a '='. E.g. typing '=Task' will find the tiddlers that contain the word 'Tas"+"k', ignoring words that just contain 'Task' as a substring.\n\n!~CaseSensitiveSearch and ~RegExpSearch"+"\nThe standard search options ~CaseSensitiveSearch and ~RegExpSearch are fully supported by YourSearc"+"h. However when ''~RegExpSearch'' is on Filtered and Boolean Search are disabled.\n\nIn addition you m"+"ay do a \"regular expression\" search even with the ''~RegExpSearch'' set to false by directly enterin"+"g the regular expression into the search field, framed with {{{/.../}}}. \n\nExample: {{{/m[ae][iy]er/"+"}}} will find all tiddlers that contain either \"maier\", \"mayer\", \"meier\" or \"meyer\".\n\n!~JavaScript E"+"xpression Filtering\nIf you are familiar with JavaScript programming and know some TiddlyWiki interna"+"ls you may also use JavaScript expression for the search. Just enter a JavaScript boolean expression"+" into the search field, framed with {{{ { ... } }}}. In the code refer to the variable tiddler and e"+"valuate to {{{true}}} when the given tiddler should be included in the result. \n\nExample: {{{ { tidd"+"ler.modified > new Date(\"Jul 4, 2005\")} }}} returns all tiddler modified after July 4th, 2005.\n\n!Com"+"bined Search\nYou are free to combine the various search options. \n\n''Examples''\n|!What you type|!Res"+"ult|\n|{{{!jonny !jeremy -%football}}}|all tiddlers with both {{{jonny}}} and {{{jeremy}}} in its tit"+"les, but no {{{football}}} in content.|\n|{{{#=Task}}}|All tiddlers tagged with 'Task' (the exact wor"+"d). Tags named '~CompletedTask', '~TaskForce' etc. are not considered.|\n\n!Access Keys\nYou are encour"+"aged to use the access keys (also called \"shortcut\" keys) for the most frequently used operations. F"+"or quick reference these shortcuts are also mentioned in the tooltip for the various buttons etc.\n\n|"+"!Key|!Operation|\n|{{{Alt-F}}}|''The most important keystroke'': It moves the cursor to the search in"+"put field so you can directly start typing your query. Pressing {{{Alt-F}}} will also display the pr"+"evious search result. This way you can quickly display multiple tiddlers using \"Press {{{Alt-F}}}. S"+"elect tiddler.\" sequences.|\n|{{{ESC}}}|Closes the [[YourSearch Result]]. When the [[YourSearch Resul"+"t]] is already closed and the cursor is in the search input field the field's content is cleared so "+"you start a new query.|\n|{{{Alt-1}}}, {{{Alt-2}}},... |Pressing these keys opens the first, second e"+"tc. tiddler from the result list.|\n|{{{Alt-O}}}|Opens all found tiddlers.|\n|{{{Alt-P}}}|Toggles the "+"'Preview Text' mode.|\n|{{{Alt-'<'}}}, {{{Alt-'>'}}}|Displays the previous or next page in the [[Your"+"Search Result]].|\n|{{{Return}}}|When you have turned off the 'as you type' search mode pressing the "+"{{{Return}}} key actually starts the search (as does pressing the 'search' button).|\n\n//If some of t"+"hese shortcuts don't work for you check your browser if you have other extensions installed that alr"+"eady \"use\" these shortcuts.//";config.shadowTiddlers["YourSearch Options"]="|>|!YourSearch Options|\n|>|<<option chkUseYourSearch>> Use 'Your Search'|\n|!|<<option chkPreviewText"+">> Show Text Preview|\n|!|<<option chkSearchAsYouType>> 'Search As You Type' Mode (No RETURN required"+" to start search)|\n|!|Default Search Filter:<<option chkSearchInTitle>>Title ('!')     <<option chk"+"SearchInText>>Text ('%')     <<option chkSearchInTags>>Tags ('#')    <<option chkSearchExtendedFiel"+"ds>>Extended Fields<html><br><font size=\"-2\">The fields of a tiddlers that are searched when you don"+"'t explicitly specify a filter in the search text <br>(Explictly specify fields using one or more '!"+"', '%', '#' or 'fieldname:' prefix before the word/text to find).</font></html>|\n|!|Number of items "+"on search result page: <<option txtItemsPerPage>>|\n|!|Number of items on search result page with pre"+"view text: <<option txtItemsPerPageWithPreview>>|\n";config.shadowTiddlers["YourSearchStyleSheet"]="/***\n!~YourSearchResult Stylesheet\n***/\n/*{{{*/\n.yourSearchResult {\n\tposition: absolute;\n\twidth: 800"+"px;\n\n\tpadding: 0.2em;\n\tlist-style: none;\n\tmargin: 0;\n\n\tbackground: #ffd;\n\tborder: 1px solid DarkGra"+"y;\n}\n\n/*}}}*/\n/***\n!!Summary Section\n***/\n/*{{{*/\n.yourSearchResult .summary {\n\tborder-bottom-width:"+" thin;\n\tborder-bottom-style: solid;\n\tborder-bottom-color: #999999;\n\tpadding-bottom: 4px;\n}\n\n.yourSea"+"rchRange, .yourSearchCount, .yourSearchQuery   {\n\tfont-weight: bold;\n}\n\n.yourSearchResult .summary ."+"button {\n\tfont-size: 10px;\n\n\tpadding-left: 0.3em;\n\tpadding-right: 0.3em;\n}\n\n.yourSearchResult .summa"+"ry .chkBoxLabel {\n\tfont-size: 10px;\n\n\tpadding-right: 0.3em;\n}\n\n/*}}}*/\n/***\n!!Items Area\n***/\n/*{{{*"+"/\n.yourSearchResult .marked {\n\tbackground: none;\n\tfont-weight: bold;\n}\n\n.yourSearchItem {\n\tmargin-to"+"p: 2px;\n}\n\n.yourSearchNumber {\n\tcolor: #808080;\n}\n\n\n.yourSearchTags {\n\tcolor: #008000;\n}\n\n.yourSearc"+"hText {\n\tcolor: #808080;\n\tmargin-bottom: 6px;\n}\n\n/*}}}*/\n/***\n!!Footer\n***/\n/*{{{*/\n.yourSearchFoote"+"r {\n\tmargin-top: 8px;\n\tborder-top-width: thin;\n\tborder-top-style: solid;\n\tborder-top-color: #999999;"+"\n}\n\n.yourSearchFooter a:hover{\n\tbackground: none;\n\tcolor: none;\n}\n/*}}}*/\n/***\n!!Navigation Bar\n***/"+"\n/*{{{*/\n.yourSearchNaviBar a {\n\tfont-size: 16px;\n\tmargin-left: 4px;\n\tmargin-right: 4px;\n\tcolor: bla"+"ck;\n\ttext-decoration: underline;\n}\n\n.yourSearchNaviBar a:hover {\n\tbackground-color: none;\n}\n\n.yourSe"+"archNaviBar .prev {\n\tfont-weight: bold;\n\tcolor: blue;\n}\n\n.yourSearchNaviBar .currentPage {\n\tcolor: #"+"FF0000;\n\tfont-weight: bold;\n\ttext-decoration: none;\n}\n\n.yourSearchNaviBar .next {\n\tfont-weight: bold"+";\n\tcolor: blue;\n}\n/*}}}*/\n";config.shadowTiddlers["YourSearchResultTemplate"]="<!--\n{{{\n-->\n<span macro=\"yourSearch if found\">\n<!-- The Summary Header ============================"+"================ -->\n<table class=\"summary\" border=\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"0\">"+"<tbody>\n  <tr>\n\t<td align=\"left\">\n\t\tYourSearch Result <span class=\"yourSearchRange\" macro=\"yourSearc"+"h itemRange\"></span>\n\t\t&nbsp;of&nbsp;<span class=\"yourSearchCount\" macro=\"yourSearch count\"></span>\n"+"\t\tfor&nbsp;<span class=\"yourSearchQuery\" macro=\"yourSearch query\"></span>\n\t</td>\n\t<td class=\"yourSea"+"rchButtons\" align=\"right\">\n\t\t<span macro=\"yourSearch chkPreviewText\"></span><span class=\"chkBoxLabel"+"\">preview text</span>\n\t\t<span macro=\"yourSearch newTiddlerButton\"></span>\n\t\t<span macro=\"yourSearch openAllButton\"></span>\n\t\t<span macro=\"yourSearch lin"+"kButton 'YourSearch Options' options 'Configure YourSearch'\"></span>\n\t\t<span macro=\"yourSearch linkB"+"utton 'YourSearch Help' help 'Get help how to use YourSearch'\"></span>\n\t\t<span macro=\"yourSearch clo"+"seButton\"></span>\n\t</td>\n  </tr>\n</tbody></table>\n\n<!-- The List of Found Tiddlers ================="+"=========================== -->\n<div id=\"yourSearchResultItems\" itemsPerPage=\"25\" itemsPerPageWithPr"+"eview=\"10\"></div>\n\n<!-- The Footer (with the Navigation) ==========================================="+"= -->\n<table class=\"yourSearchFooter\" border=\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"0\"><tbody"+">\n  <tr>\n\t<td align=\"left\">\n\t\tResult page: <span class=\"yourSearchNaviBar\" macro=\"yourSearch naviBar"+"\"></span>\n\t</td>\n\t<td align=\"right\"><span macro=\"yourSearch version\"></span>, <span macro=\"yourSearc"+"h copyright\"></span>\n\t</td>\n  </tr>\n</tbody></table>\n<!-- end of the 'tiddlers found' case ========="+"================================== -->\n</span>\n\n\n<!-- The \"No tiddlers found\" case ================="+"========================== -->\n<span macro=\"yourSearch if not found\">\n<table class=\"summary\" border="+"\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"0\"><tbody>\n  <tr>\n\t<td align=\"left\">\n\t\tYourSearch Resu"+"lt: No tiddlers found for <span class=\"yourSearchQuery\" macro=\"yourSearch query\"></span>.\n\t</td>\n\t<t"+"d class=\"yourSearchButtons\" align=\"right\">\n\t\t<span macro=\"yourSearch newTiddlerButton\"></span>\n\t\t<span macro=\"yourSearch linkButton 'YourSearch Options'"+" options 'Configure YourSearch'\"></span>\n\t\t<span macro=\"yourSearch linkButton 'YourSearch Help' help"+" 'Get help how to use YourSearch'\"></span>\n\t\t<span macro=\"yourSearch closeButton\"></span>\n\t</td>\n  <"+"/tr>\n</tbody></table>\n</span>\n\n\n<!--\n}}}\n-->\n";config.shadowTiddlers["YourSearchItemTemplate"]="<!--\n{{{\n-->\n<span class='yourSearchNumber' macro='foundTiddler number'></span>\n<span class='yourSea"+"rchTitle' macro='foundTiddler title'/></span>&nbsp;-&nbsp;\n<span class='yourSearchTags' macro='found"+"Tiddler field tags 50'/></span>\n<span macro=\"yourSearch if previewText\"><div class='yourSearchText' macro='fo"+"undTiddler field text 250'/></div></span>\n<!--\n}}}\n-->";config.shadowTiddlers["YourSearch"]="<<tiddler [[YourSearch Help]]>>";config.shadowTiddlers["YourSearch Result"]="The popup-like window displaying the result of a YourSearch query.";config.macros.search.handler=_157;var _20a=function(){if(config.macros.search.handler!=_157){alert("Message from YourSearchPlugin:\n\n\nAnother plugin has disabled the 'Your Search' features.\n\n\nYou may "+"disable the other plugin or change the load order of \nthe plugins (by changing the names of the tidd"+"lers)\nto enable the 'Your Search' features.");}};setTimeout(_20a,5000);abego.YourSearch.getStandardRankFunction=function(){return _ff;};abego.YourSearch.getRankFunction=function(){return abego.YourSearch.getStandardRankFunction();};abego.YourSearch.getCurrentTiddler=function(){return _13c;};abego.YourSearch.closeResult=function(){_12a();};abego.YourSearch.getFoundTiddlers=function(){return _f2;};abego.YourSearch.getQuery=function(){return _f3;};abego.YourSearch.onShowResult=function(_20b){highlightHack=_f3?_f3.getMarkRegExp():null;if(!_20b){_13d.setItems(_f6());}
if(!_124){_124=createTiddlyElement(document.body,"div",_121,"yourSearchResult");}else{if(_124.parentNode!=document.body){document.body.appendChild(_124);}}
_146();highlightHack=null;};})();}
//%/




//{{{
//requires DatePicker: http://svn.tiddlywiki.org/Trunk/contributors/SaqImtiaz/libraries/DatePicker.js

if (DatePicker) {

	merge(config.macros, {

		calendarPopup: {
			handler: function(place,macroName,params,wikifier,paramString,tiddler) {
				var dateBox = createTiddlyButton(place,params[0],params[1]);            
				dateBox.style.cursor='pointer';
				DatePicker.create(dateBox,(new Date()),function(el,objDate) {
					// mostly copy/pasted from NewSavedTiddler. refactor please
					var title = prompt("Enter name for new Tickler","");
					if (title) {
						if (typeof config.macros.newTiddler.getName == "function")  {
							title = config.macros.newTiddler.getName(title); // from NewMeansNewPlugin
						}
						store.saveTiddler(title,title,"",config.options.txtUserName,new Date(),"Tickler Once "+config.macros.mgtdList.getRealm(),{'mgtd_date':objDate.convertToYYYYMMDDHHMM()});
						story.displayTiddler(this,title);
					}
				});
			}
		},

		dateChooser: {
			handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    
				var useTiddler = tiddler;
				if (params[0])
					useTiddler = store.fetchTiddler(params[0]);
    
				var curVal = useTiddler.fields['mgtd_date'] || undefined;
				var startDate = curVal ? Date.convertFromYYYYMMDDHHMM(curVal) : null;

				var dateBox = createTiddlyElement(place,'input',null,'dateBox');            

				var dateFormat = config.mGTD.getOptTxt('ticklerdateformat');
				var defaultDateFormat = 'ddd, DD-mmm-YY';
				if (!dateFormat) {
					// makes it nicer for upgraders who don't have a format set
					dateFormat = defaultDateFormat;
					config.mGTD.setOptTxt('ticklerdateformat', defaultDateFormat);
				}
				dateBox.value = startDate ? startDate.formatString(dateFormat) : '(set date)';
    
				var callback = function(el,objDate){
					el.value = objDate.formatString(dateFormat);
					store.setValue(useTiddler, 'mgtd_date',objDate.convertToYYYYMMDDHHMM());
				}
				DatePicker.create(dateBox,startDate,callback);
			}
		},

		addDay: {
			label:   {addDay:"+d",  addWeek:"+w",   addMonth:"+m",    addYear:"+y"   },
			tooltip: {addDay:"day", addWeek:"week", addMonth:"month", addYear:"year" },
			handler: function(place,macroName,params,wikifier,paramString,tiddler) {
				var useTiddler = tiddler;
				if (params[0]) useTiddler = store.fetchTiddler(params[0]);
				var curVal = useTiddler.fields['mgtd_date'] || undefined;
				var curDate = curVal ? Date.convertFromYYYYMMDDHHMM(curVal) : new Date();    
				// ensure ticklers don't have minutes/hours since new Date() has minutes/hours
				curDate.setHours(0);
				curDate.setMinutes(0);
				curDate.setSeconds(0); 
				// call the applicable date method. happens to match the macroname. see MgtdDateUtils. sorry for confusing code.
				curDate[macroName](1);
				createTiddlyButton(place,config.macros.addDay.label[macroName],"add a "+config.macros.addDay.tooltip[macroName],function() {
					store.setValue(useTiddler, 'mgtd_date',curDate.convertToYYYYMMDDHHMM());
					return false;
				});

			}
		}
	});

	config.macros.addWeek  = config.macros.addDay;
	config.macros.addMonth = config.macros.addDay;
	config.macros.addYear  = config.macros.addDay;

} // if (DatePicker)

//}}}