Welcome to TiddlyWiki created by Jeremy Ruston, Copyright © 2007 UnaMesa Association
/***
|Name|AdvancedOptionsPlugin|
|Source|http://www.TiddlyTools.com/#AdvancedOptionsPlugin|
|Documentation|http://www.TiddlyTools.com/#AdvancedOptionsPlugin|
|Version|1.2.0|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.3|
|Type|plugin|
|Description|automatically add plugin-defined options to the [[AdvancedOptions]] shadow tiddler|
!!!!!Usage
<<<
At document startup, this plugin examines each tiddler tagged with <<tag systemConfig>> and looks for a tiddler slice named "Options" whose value refers to a tiddler section (or separate tiddler) that contains an 'advanced options control panel' for configuring that plugin's features and behavior. For each plugin that contains an "Options" slice, a tabbed entry is automatically created in the [[AdvancedOptions]] shadow tiddler to display that plugin's control panel.
As an optional fallback for backward-compatibility with plugin tiddlers that do not define the "Options" slice, this plugin will also look for a section heading named "Configuration" within those tiddlers, so that older plugins that define this section can automatically have their settings added to the [[AdvancedOptions]] tiddler without requiring the "Options" slice to be added.
This plugin also extends the standard {{{<<option>>}}} macro syntax so you can directly set the internal value of a boolean or text option, without displaying a corresponding checkbox or input field control simply by appending {{{=value}}} syntax to the end of the option ID parameter:
{{{
<<option "txtSomeOption=some text">>
<<option chkSomeOtherOption=true>> OR <<option chkSomeOtherOption=false>>
}}}
Example: {{{<<option chkAnimate=false>>}}}
<<<
!!!!!Configuration
<<<
<<option chkAdvancedOptions>> automatically add plugin-defined options to the [[AdvancedOptions]] shadow tiddler
<<option chkAdvancedOptionsBackstage>> automatically add plugin-defined options to Backstage menu
<<option chkAdvancedOptionsFallback>> use <<option txtAdvancedOptionsFallback>> section as a fallback for plugins that don't define an ~AdvancedOptions slice
//note: these settings only take effect after reloading the document//
<<<
!!!!!Revisions
<<<
2009.07.23 [1.2.0] added support for enhanced {{{<<option id=value>>}}} 'direct assignment' syntax
2008.05.09 [1.1.0] add "options" panel to backstage
2008.04.08 [1.0.0] initial release
<<<
!!!!!Code
***/
//{{{
version.extensions.AdvancedOptionsPlugin= {major: 1, minor: 2, revision: 0, date: new Date(2009,7,23)};
if (config.options.chkAdvancedOptions===undefined)
config.options.chkAdvancedOptions=true;
if (config.options.chkAdvancedOptionsBackstage===undefined)
config.options.chkAdvancedOptionsBackstage=true;
if (config.options.chkAdvancedOptionsFallback===undefined)
config.options.chkAdvancedOptionsFallback=true;
if (config.options.txtAdvancedOptionsFallback===undefined)
config.options.txtAdvancedOptionsFallback="Configuration";
if (config.optionsDesc) config.optionsDesc.chkAdvancedOptions=
"automatically add plugin-defined options to [[AdvancedOptions]]";
//}}}
//{{{
var items=[];
var fmt="[[%0 ]] [[view options for %0]] [[%1]]\n";
var section=config.options.txtAdvancedOptionsFallback;
var plugins=store.getTaggedTiddlers("systemConfig");
for (var p=0; p<plugins.length; p++) {
var tid=plugins[p].title;
var settings=store.getTiddlerSlice(tid,"Options");
if (!settings && config.options.chkAdvancedOptionsFallback && store.getTiddlerText(tid+"##"+section))
settings="##"+section; // fallback handling for older plugins
if (settings&&settings.length) {
if (settings.substr(0,2)=="##") settings=tid+settings;
items.push(fmt.format([tid,settings]));
}
}
if (items.length) config.shadowTiddlers.PluginOptions=
"!![[Plugin-defined options|PluginManager]]\n>@@text-align:left;<<tabs '' \n"+items.join(' ')+">>@@";
if (config.options.chkAdvancedOptions)
config.shadowTiddlers.AdvancedOptions+="{{smallform{{{wrap{<<tiddler PluginOptions>>}}}}}}";
//}}}
//{{{
// // add "options" backstage task
if (config.tasks && config.options.chkAdvancedOptionsBackstage) { // for TW2.2b3 or above
config.tasks.options = {
text: "options",
tooltip: "manage plugin-defined option settings",
content: "{{smallform{{{groupbox{{{wrap{<<tiddler PluginOptions>>}}}}}}\n{{groupbox small {<<options>>}}}}}}"
}
config.backstageTasks.splice(config.backstageTasks.indexOf("plugins")+1,0,"options");
}
//}}}
//{{{
config.macros.option.AOPsave_handler=config.macros.option.handler;
config.macros.option.handler=function(place,macroName,params,wikifier,paramString,tiddler) {
var parts=params[0].split('=');
if (parts.length==1) return this.AOPsave_handler.apply(this,arguments);
var id=parts[0]; var val=(id.substr(0,3)=='txt')?parts[1]:(parts[1]=='true');
config.options[id]=val;
}
//}}}
/***
|''Name:''|AnnotationsPlugin|
|''Description:''|Inline annotations for tiddler text.|
|''Author:''|Saq Imtiaz ( lewcid@gmail.com )|
|''Source:''|http://tw.lewcid.org/#AnnotationsPlugin|
|''Code Repository:''|http://tw.lewcid.org/svn/plugins|
|''Version:''|2.0|
|''Date:''||
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|
|''~CoreVersion:''|2.2.3|
!!Usage:
*{{{((text to annotate(annotation goes here)}}}
* To include the text being annotated, in the popup as a title, put {{{^}}} as the first letter of the annotation text.
** {{{((text to annotate(^annotation goes here)}}}
!!Examples:
Mouse over, the text below:
* ((banana(the best fruit in the world)))
* ((banana(^ the best fruit in the world)))
***/
// /%
config.formatters.unshift({name:"annotations",match:"\\(\\(",lookaheadRegExp:/\(\((.*?)\((\^?)((?:.|\n)*?)\)\)\)/g,handler:function(w){
this.lookaheadRegExp.lastIndex=w.matchStart;
var _2=this.lookaheadRegExp.exec(w.source);
if(_2&&_2.index==w.matchStart){
var _3=createTiddlyElement(w.output,"span",null,"annosub",_2[1]);
_3.anno=_2[3];
if(_2[2]){
_3.subject=_2[1];
}
_3.onmouseover=this.onmouseover;
_3.onmouseout=this.onmouseout;
_3.ondblclick=this.onmouseout;
w.nextMatch=_2.index+_2[0].length;
}
},onmouseover:function(e){
popup=createTiddlyElement(document.body,"div",null,"anno");
this.popup=popup;
if(this.subject){
wikify("!"+this.subject+"\n",popup);
}
wikify(this.anno,popup);
addClass(this,"annosubover");
Popup.place(this,popup,{x:25,y:7});
},onmouseout:function(e){
removeNode(this.popup);
this.popup=null;
removeClass(this,"annosubover");
}});
setStylesheet(".anno{position:absolute;border:2px solid #000;background-color:#DFDFFF; color:#000;padding:0.5em;max-width:15em;width:expression(document.body.clientWidth > (255/12) *parseInt(document.body.currentStyle.fontSize)?'15em':'auto' );}\n"+".anno h1, .anno h2{margin-top:0;color:#000;}\n"+".annosub{background:#ccc;}\n"+".annosubover{z-index:25; background-color:#DFDFFF;cursor:help;}\n","AnnotationStyles");
// %/
/***
|''Name:''|ArchivePlugin|
|''Version:''|2.4.0 (2 Jun 2008)|
|''Source''|http://jackparke.googlepages.com/jtw.html#ArchivePlugin ([[del.icio.us|http://del.icio.us/post?url=http://jackparke.googlepages.com/jtw.html%23ArchivePlugin]])|
|''Author:''|[[Jack]]|
|''Type:''|Plugin|
!Description
The archive plugin allows you to store tiddler text outside of the tiddlywiki file.
Typically you would tag bulky tiddlers or those with infrequently needed content as "Archive" and these would
then be archived as separate html files in the sub folder called "archive".
!Usage
#Create a folder "archive" in the same folder as your tiddlywiki file.
#Install the Archive Plugin and reload your tiddlywiki
#Tag your bulky tiddlers with "Archive"
#Save your tiddlywiki file
!To Do
* Synchronize tiddler renames/deletions with file system
* Lazy loading of archived files via HTTP
/%
!Code
***/
version.extensions.ArchivePlugin = {major: 2, minor: 4, revision: 0, date: new Date("Jun 6, 2008")};
config.macros.ArchivePlugin = {};
config.macros.ArchivePlugin.init = function () {
this.archivePath = getWikiPath('archive');
}
// Hijacking the built-in functions
TW21Saver.prototype.externalizeTiddler = function(store,tiddler)
{
try {
var extendedAttributes = "";
var usePre = config.options.chkUsePreForStorage;
store.forEachField(tiddler,
function(tiddler,fieldName,value) {
// don't store stuff from the temp namespace
if(typeof value != "string")
value = "";
if (!fieldName.match(/^temp\./))
extendedAttributes += ' %0="%1"'.format([fieldName,value.escapeLineBreaks().htmlEncode()]);
},true);
var created = tiddler.created.convertToYYYYMMDDHHMM();
var modified = tiddler.modified.convertToYYYYMMDDHHMM();
var vdate = version.date.convertToYYYYMMDDHHMM();
var attributes = tiddler.modifier ? ' modifier="' + tiddler.modifier.htmlEncode() + '"' : "";
attributes += (usePre && modified == created) ? "" : ' modified="' + modified +'"';
attributes += (usePre && created == vdate) ? "" :' created="' + created + '"';
var tags = tiddler.getTags();
if(!usePre || tags)
attributes += ' tags="' + tags.htmlEncode() + '"';
return ('<div %0="%1"%2%3>%4</'+'div>').format([
usePre ? "title" : "tiddler",
tiddler.title.htmlEncode(),
attributes,
extendedAttributes,
usePre ? "\n<pre>" + tiddler.saveMe() + "</pre>\n" : tiddler.escapeLineBreaks().htmlEncode()
]);
} catch (ex) {
throw exceptionText(ex,config.messages.tiddlerSaveError.format([tiddler.title]));
}
};
Tiddler.prototype.saveMe = function() {
if (this.tags.indexOf('Archive') != -1) {
// Save tiddler body to a file in the archive folder
if (this.text) saveFile(config.macros.ArchivePlugin.archivePath + this.title.filenameEncode() + '.html', this.text)
return '';
}
else
return this.text.htmlEncode();
}
// This hijack ensures plugins can also be archived
var archivePlugin_getPluginInfo = getPluginInfo;
getPluginInfo = function(tiddler) {
alert(tiddler.title)
tiddler.text = store.getValue(tiddler, 'text');
return archivePlugin_getPluginInfo(tiddler);
}
TiddlyWiki.prototype.getValue = function(tiddler, fieldName) {
var t = this.resolveTiddler(tiddler);
if (!t)
return undefined;
fieldName = fieldName.toLowerCase();
if (t.tags.indexOf('Archive')!=-1 && fieldName=='text' && t['text']=='') {
try {
var tmp = loadFile(config.macros.ArchivePlugin.archivePath + t.title.filenameEncode() + '.html');
tmp = (tmp.charCodeAt(0) == 239 ? manualConvertUTF8ToUnicode(tmp) : tmp);
} catch (e) {
return ''; //alert("{{{Error: Unable to load file '" + config.macros.ArchivePlugin.archivePath + t.title.filenameEncode() + '.html' + "'}}}");
}
return tmp;
} else {
var accessor = TiddlyWiki.standardFieldAccess[fieldName];
if (accessor) {
return accessor.get(t);
}
}
return t.fields ? t.fields[fieldName] : undefined;
}
String.prototype.filenameEncode = function() {
return(this.toLowerCase().replace(/[^a-z0-9_-]/g ,"_"));
}
function getWikiPath(folderName) {
var originalPath = document.location.toString();
if(originalPath.substr(0,5) != 'file:') {
alert(config.messages.notFileUrlError);
if(store.tiddlerExists(config.messages.saveInstructions))
story.displayTiddler(null,config.messages.saveInstructions);
return;
}
var localPath = getLocalPath(originalPath);
var backSlash = localPath.lastIndexOf('\\') == -1 ? '/' : '\\';
var dirPathPos = localPath.lastIndexOf(backSlash);
var fileName = localPath.substring(dirPathPos+1,localPath.lastIndexOf('.'));
folderName += backSlash + fileName;
var subPath = localPath.substr(0,dirPathPos) + backSlash + (folderName ? folderName + backSlash : '');
return subPath;
}
// Deleting archive files
TiddlyWiki.prototype.archivePlugin_removeTiddler = TiddlyWiki.prototype.removeTiddler;
TiddlyWiki.prototype.removeTiddler = function(title) {
var tiddler = store.getTiddler(title);
var filePath = config.macros.ArchivePlugin.archivePath + title.filenameEncode() + '.html';
if (tiddler.tags.indexOf('Archive') != -1) ieDeleteFile(filePath);
this.archivePlugin_removeTiddler(title);
}
function ieDeleteFile(filePath) {
// IE Support only
if (!config.browser.isIE) return false;
try {
var fso = new ActiveXObject("Scripting.FileSystemObject");
} catch(ex) {return null;}
try {
var file = fso.GetFile(filePath);
file.Delete();
} catch(ex) {return null;}
return true;
}
//%/
<<myComment>>
----
~~:::::__Fri Jun 25 2010 19:16:34 GMT-0400 (Eastern Daylight Time)__:::::~~
BUG? keep popping up on page load when open via http.
----
~~:::::__Fri Jun 25 2010 19:17:18 GMT-0400 (Eastern Daylight Time)__:::::~~
Change: archivePath = archive\FILENAME\tiddlerTitle
text/plain
.txt .text .js .vbs .asp .cgi .pl
----
text/html
.htm .html .hta .htx .mht
----
text/comma-separated-values
.csv
----
text/javascript
.js
----
text/css
.css
----
text/xml
.xml .xsl .xslt
----
image/gif
.gif
----
image/jpeg
.jpg .jpe .jpeg
----
image/png
.png
----
image/bmp
.bmp
----
image/tiff
.tif .tiff
----
audio/basic
.au .snd
----
audio/wav
.wav
----
audio/x-pn-realaudio
.ra .rm .ram
----
audio/x-midi
.mid .midi
----
audio/mp3
.mp3
----
audio/m3u
.m3u
----
video/x-ms-asf
.asf
----
video/avi
.avi
----
video/mpeg
.mpg .mpeg
----
video/quicktime
.qt .mov .qtvr
----
application/pdf
.pdf
----
application/rtf
.rtf
----
application/postscript
.ai .eps .ps
----
application/wordperfect
.wpd
----
application/mswrite
.wri
----
application/msexcel
.xls .xls3 .xls4 .xls5 .xlw
----
application/msword
.doc
----
application/mspowerpoint
.ppt .pps
----
application/x-director
.swa
----
application/x-shockwave-flash
.swf
----
application/x-zip-compressed
.zip
----
application/x-gzip
.gz
----
application/x-rar-compressed
.rar
----
application/octet-stream
.com .exe .dll .ocx
----
application/java-archive
.jar
/***
|Name|AttachFilePlugin|
|Source|http://www.TiddlyTools.com/#AttachFilePlugin|
|Documentation|http://www.TiddlyTools.com/#AttachFilePluginInfo|
|Version|4.0.0|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Requires|AttachFilePluginFormatters, AttachFileMIMETypes|
|Description|Store binary files as base64-encoded tiddlers with fallback links for separate local and/or remote file storage|
Store or link binary files (such as jpg, gif, pdf or even mp3) within your TiddlyWiki document and then use them as images or links from within your tiddler content.
> Important note: As of version 3.6.0, in order to //render// images and other binary attachments created with this plugin, you must also install [[AttachFilePluginFormatters]], which extends the behavior of the TiddlyWiki core formatters for embedded images ({{{[img[tooltip|image]]}}}), linked embedded images ({{{[img[tooltip|image][link]]}}}), and external/"pretty" links ({{{[[label|link]]}}}), so that these formatter will process references to attachment tiddlers as if a normal file reference had been provided. |
!!!!!Documentation
>see [[AttachFilePluginInfo]]
!!!!!Inline interface (live)
>see [[AttachFile]] (shadow tiddler)
><<tiddler AttachFile>>
!!!!!Revisions
<<<
2009.06.04 [4.0.0] changed attachment storage format to use //sections// instead of embedded substring markers.
|please see [[AttachFilePluginInfo]] for additional revision details|
2005.07.20 [1.0.0] Initial Release
<<<
!!!!!Code
***/
// // version
//{{{
version.extensions.AttachFilePlugin= {major: 4, minor: 0, revision: 0, date: new Date(2009,6,4)};
//config
if(!config.options.chkAttachFileShowData) config.options.chkAttachFileShowData=false;
// shadow tiddler
config.shadowTiddlers.AttachFile="<<attach inline>>";
// add 'attach' backstage task (insert before built-in 'importTask')
if (config.tasks) { // for TW2.2b or above
config.tasks.attachTask = {
text: "attach",
tooltip: "Attach a binary file as a tiddler",
content: "<<attach inline>>"
}
config.backstageTasks.splice(config.backstageTasks.indexOf("importTask"),0,"attachTask");
}
config.macros.attach = {
// // lingo
//{{{
label: "attach file",
tooltip: "Attach a file to this document",
linkTooltip: "Attachment: ",
typeList: "AttachFileMIMETypes",
titlePrompt: " enter tiddler title...",
MIMEPrompt: "<option value=''>select MIME type...</option><option value='editlist'>[edit list...]</option>",
localPrompt: " enter local path/filename...",
URLPrompt: " enter remote URL...",
tiddlerErr: "Please enter a tiddler title",
sourceErr: "Please enter a source path/filename",
storageErr: "Please select a storage method: embedded, local or remote",
MIMEErr: "Unrecognized file format. Please select a MIME type",
localErr: "Please enter a local path/filename",
URLErr: "Please enter a remote URL",
fileErr: "Invalid path/file or file not found",
tiddlerFormat: '!usage\n{{{%0}}}\n%0\n!notes\n%1\n!type\n%2\n!file\n%3\n!url\n%4\n!hiddenData\n/\u0025\n!data\n%5\n!endHiddenData\n\u0025/',
//}}}
// // macro definition
//{{{
handler:
function(place,macroName,params) {
if (params && !params[0])
{ createTiddlyButton(place,this.label,this.tooltip,this.toggleAttachPanel); return; }
var id=params.shift();
this.createAttachPanel(place,id+"_attachPanel",params);
document.getElementById(id+"_attachPanel").style.position="static";
document.getElementById(id+"_attachPanel").style.display="block";
},
//}}}
//{{{
createAttachPanel:
function(place,panel_id,params) {
if (!panel_id || !panel_id.length) var panel_id="_attachPanel";
// remove existing panel (if any)
var panel=document.getElementById(panel_id); if (panel) panel.parentNode.removeChild(panel);
// set styles for this panel
setStylesheet(this.css,"attachPanel");
// create new panel
var title=""; if (params && params[0]) title=params.shift();
var types=this.MIMEPrompt+this.formatListOptions(store.getTiddlerText(this.typeList)); // get MIME types
panel=createTiddlyElement(place,"span",panel_id,"attachPanel",null);
var html=this.html.replace(/%id%/g,panel_id);
html=html.replace(/%title%/g,title);
html=html.replace(/%disabled%/g,title.length?"disabled":"");
html=html.replace(/%IEdisabled%/g,config.browser.isIE?"disabled":"");
html=html.replace(/%types%/g,types);
panel.innerHTML=html;
if (config.browser.isGecko) { // FF3 FIXUP
document.getElementById("attachSource").style.display="none";
document.getElementById("attachFixPanel").style.display="block";
}
return panel;
},
//}}}
//{{{
toggleAttachPanel:
function (e) {
if (!e) var e = window.event;
var parent=resolveTarget(e).parentNode;
var panel = document.getElementById("_attachPanel");
if (panel==undefined || panel.parentNode!=parent)
panel=config.macros.attach.createAttachPanel(parent,"_attachPanel");
var isOpen = panel.style.display=="block";
if(config.options.chkAnimate)
anim.startAnimating(new Slider(panel,!isOpen,e.shiftKey || e.altKey,"none"));
else
panel.style.display = isOpen ? "none" : "block" ;
e.cancelBubble = true;
if (e.stopPropagation) e.stopPropagation();
return(false);
},
//}}}
//{{{
formatListOptions:
function(text) {
if (!text || !text.trim().length) return "";
// get MIME list content from text
var parts=text.split("\n----\n");
var out="";
for (var p=0; p<parts.length; p++) {
var lines=parts[p].split("\n");
var label=lines.shift(); // 1st line=display text
var value=lines.shift(); // 2nd line=item value
out +='<option value="%1">%0</option>'.format([label,value]);
}
return out;
},
//}}}
// // interface definition
//{{{
css:
".attachPanel { display: none; position:absolute; z-index:10; width:35em; right:105%; top:0em;\
background-color: #eee; color:#000; font-size: 8pt; line-height:110%;\
border:1px solid black; border-bottom-width: 3px; border-right-width: 3px;\
padding: 0.5em; margin:0em; -moz-border-radius:1em;-webkit-border-radius:1em; text-align:left }\
.attachPanel form { display:inline;border:0;padding:0;margin:0; }\
.attachPanel select { width:99%;margin:0px;font-size:8pt;line-height:110%;}\
.attachPanel input { width:98%;padding:0px;margin:0px;font-size:8pt;line-height:110%}\
.attachPanel textarea { width:98%;margin:0px;height:2em;font-size:8pt;line-height:110%}\
.attachPanel table { width:100%;border:0;margin:0;padding:0;color:inherit; }\
.attachPanel tbody, .attachPanel tr, .attachPanel td { border:0;margin:0;padding:0;color:#000; }\
.attachPanel .box { border:1px solid black; padding:.3em; margin:.3em 0px; background:#f8f8f8; \
-moz-border-radius:5px;-webkit-border-radius:5px; }\
.attachPanel .chk { width:auto;border:0; }\
.attachPanel .btn { width:auto; }\
.attachPanel .btn2 { width:49%; }\
",
//}}}
//{{{
html:
'<form>\
attach from source file\
<input type="file" id="attachSource" name="source" size="56"\
onChange="config.macros.attach.onChangeSource(this)">\
<div id="attachFixPanel" style="display:none"><!-- FF3 FIXUP -->\
<input type="text" id="attachFixSource" style="width:90%"\
title="Enter a path/file to attach"\
onChange="config.macros.attach.onChangeSource(this);">\
<input type="button" style="width:7%" value="..."\
title="Enter a path/file to attach"\
onClick="config.macros.attach.askForFilename(document.getElementById(\'attachFixSource\'));">\
</div><!--end FF3 FIXUP-->\
<div class="box">\
<table style="border:0"><tr style="border:0"><td style="border:0;text-align:right;width:1%;white-space:nowrap">\
embed data <input type=checkbox class=chk name="useData" %IEdisabled% \
onclick="if (!this.form.MIMEType.value.length)\
this.form.MIMEType.selectedIndex=this.checked?1:0; "> \
</td><td style="border:0">\
<select size=1 name="MIMEType" \
onchange="this.title=this.value; if (this.value==\'editlist\')\
{ this.selectedIndex=this.form.useData.checked?1:0; story.displayTiddler(null,config.macros.attach.typeList,2); return; }">\
<option value=""></option>\
%types%\
</select>\
</td></tr><tr style="border:0"><td style="border:0;text-align:right;width:1%;white-space:nowrap">\
local link <input type=checkbox class=chk name="useLocal"\
onclick="this.form.local.value=this.form.local.defaultValue=this.checked?config.macros.attach.localPrompt:\'\';"> \
</td><td style="border:0">\
<input type=text name="local" size=15 autocomplete=off value=""\
onchange="this.form.useLocal.checked=this.value.length" \
onkeyup="this.form.useLocal.checked=this.value.length" \
onfocus="if (!this.value.length) this.value=config.macros.attach.localPrompt; this.select()">\
</td></tr><tr style="border:0"><td style="border:0;text-align:right;width:1%;white-space:nowrap">\
remote link <input type=checkbox class=chk name="useURL"\
onclick="this.form.URL.value=this.form.URL.defaultValue=this.checked?config.macros.attach.URLPrompt:\'\';\"> \
</td><td style="border:0">\
<input type=text name="URL" size=15 autocomplete=off value=""\
onfocus="if (!this.value.length) this.value=config.macros.attach.URLPrompt; this.select()"\
onchange="this.form.useURL.checked=this.value.length;"\
onkeyup="this.form.useURL.checked=this.value.length;">\
</td></tr></table>\
</div>\
<table style="border:0"><tr style="border:0"><td style="border:0;text-align:right;vertical-align:top;width:1%;white-space:nowrap">\
notes \
</td><td style="border:0" colspan=2>\
<textarea name="notes" style="width:98%;height:3.5em;margin-bottom:2px"></textarea>\
</td><tr style="border:0"><td style="border:0;text-align:right;width:1%;white-space:nowrap">\
attach as \
</td><td style="border:0" colspan=2>\
<input type=text name="tiddlertitle" size=15 autocomplete=off value="%title%"\
onkeyup="if (!this.value.length) { this.value=config.macros.attach.titlePrompt; this.select(); }"\
onfocus="if (!this.value.length) this.value=config.macros.attach.titlePrompt; this.select()" %disabled%>\
</td></tr></tr><tr style="border:0"><td style="border:0;text-align:right;width:1%;white-space:nowrap">\
add tags \
</td><td style="border:0">\
<input type=text name="tags" size=15 autocomplete=off value="" onfocus="this.select()">\
</td><td style="width:40%;text-align:right;border:0">\
<input type=button class=btn2 value="attach"\
onclick="config.macros.attach.onClickAttach(this)"><!--\
--><input type=button class=btn2 value="close"\
onclick="var panel=document.getElementById(\'%id%\'); if (panel) panel.parentNode.removeChild(panel);">\
</td></tr></table>\
</form>',
//}}}
// // control processing
//{{{
onChangeSource:
function(here) {
var form=here.form;
var list=form.MIMEType;
var theFilename = here.value;
var theExtension = theFilename.substr(theFilename.lastIndexOf('.')).toLowerCase();
// if theFilename is in current document folder, remove path prefix and use relative reference
var h=document.location.href; folder=getLocalPath(decodeURIComponent(h.substr(0,h.lastIndexOf("/")+1)));
if (theFilename.substr(0,folder.length)==folder) theFilename='./'+theFilename.substr(folder.length);
else theFilename='file:///'+theFilename; // otherwise, use absolute reference
theFilename=theFilename.replace(/\\/g,"/"); // fixup: change \ to /
form.useLocal.checked = true;
form.local.value = theFilename;
form.useData.checked = !form.useData.disabled;
list.selectedIndex=1;
for (var i=0; i<list.options.length; i++) // find matching MIME type
if (list.options[i].value.indexOf(theExtension)!=-1) { list.selectedIndex = i; break; }
if (!form.tiddlertitle.disabled)
form.tiddlertitle.value=theFilename.substr(theFilename.lastIndexOf('/')+1); // get tiddlername from filename
},
//}}}
//{{{
onClickAttach:
function (here) {
clearMessage();
// get input values
var form=here.form;
var src=form.source; if (config.browser.isGecko) src=document.getElementById("attachFixSource");
src=src.value!=src.defaultValue?src.value:"";
var when=(new Date()).formatString(config.macros.timeline.dateFormat);
var title=form.tiddlertitle.value;
var local = form.local.value!=form.local.defaultValue?form.local.value:"";
var url = form.URL.value!=form.URL.defaultValue?form.URL.value:"";
var notes = form.notes.value;
var tags = "attachment excludeMissing "+form.tags.value;
var useData=form.useData.checked;
var useLocal=form.useLocal.checked;
var useURL=form.useURL.checked;
var mimetype = form.MIMEType.value.length?form.MIMEType.options[form.MIMEType.selectedIndex].text:"";
// validate checkboxes and get filename
if (useData) {
if (src.length) { if (!theLocation) var theLocation=src; }
else { alert(this.sourceErr); src.focus(); return false; }
}
if (useLocal) {
if (local.length) { if (!theLocation) var theLocation = local; }
else { alert(this.localErr); form.local.focus(); return false; }
}
if (useURL) {
if (url.length) { if (!theLocation) var theLocation = url; }
else { alert(this.URLErr); form.URL.focus(); return false; }
}
if (!(useData||useLocal||useURL))
{ form.useData.focus(); alert(this.storageErr); return false; }
if (!theLocation)
{ src.focus(); alert(this.sourceErr); return false; }
if (!title || !title.trim().length || title==this.titlePrompt)
{ form.tiddlertitle.focus(); alert(this.tiddlerErr); return false; }
// if not already selected, determine MIME type based on filename extension (if any)
if (useData && !mimetype.length && theLocation.lastIndexOf('.')!=-1) {
var theExt = theLocation.substr(theLocation.lastIndexOf('.')).toLowerCase();
var theList=form.MIMEType;
for (var i=0; i<theList.options.length; i++)
if (theList.options[i].value.indexOf(theExt)!=-1)
{ var mimetype=theList.options[i].text; theList.selectedIndex=i; break; }
}
// attach the file
return this.createAttachmentTiddler(src, when, notes, tags, title,
useData, useLocal, useURL, local, url, mimetype);
},
getMIMEType:
function(src,def) {
var ext = src.substr(src.lastIndexOf('.')).toLowerCase();
var list=store.getTiddlerText(this.typeList);
if (!list || !list.trim().length) return def;
// get MIME list content from tiddler
var parts=list.split("\n----\n");
for (var p=0; p<parts.length; p++) {
var lines=parts[p].split("\n");
var mime=lines.shift(); // 1st line=MIME type
var match=lines.shift(); // 2nd line=matching extensions
if (match.indexOf(ext)!=-1) return mime;
}
return def;
},
createAttachmentTiddler:
function (src, when, notes, tags, title, useData, useLocal, useURL, local, url, mimetype, noshow) {
if (useData) { // encode the data
if (!mimetype.length) {
alert(this.MIMEErr);
form.MIMEType.selectedIndex=1; form.MIMEType.focus();
return false;
}
var d = this.readFile(src); if (!d) { return false; }
displayMessage('encoding '+src);
var encoded = this.encodeBase64(d);
displayMessage('file size='+d.length+' bytes, encoded size='+encoded.length+' bytes');
}
var usage=(mimetype.substr(0,5)=="image"?'[img[%0]]':'[[%0|%0]]').format([title]);
var theText=this.tiddlerFormat.format([
usage, notes.length?notes:'//none//', mimetype,
useLocal?local.replace(/\\/g,'/'):'', useURL?url:'',
useData?('data:'+mimetype+';base64,'+encoded):'' ]);
store.saveTiddler(title,title,theText,config.options.txtUserName,new Date(),tags);
var panel=document.getElementById("attachPanel"); if (panel) panel.style.display="none";
if (!noshow) { story.displayTiddler(null,title); story.refreshTiddler(title,null,true); }
if(useData) displayMessage('attached "'+title+'"');
else displayMessage('linked"'+title+'"');
return true;
},
//}}}
// // base64 conversion
//{{{
encodeBase64:
function (d) {
if (!d) return null;
// encode as base64
var keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
var out="";
var chr1,chr2,chr3="";
var enc1,enc2,enc3,enc4="";
for (var count=0,i=0; i<d.length; ) {
chr1=d.charCodeAt(i++);
chr2=d.charCodeAt(i++);
chr3=d.charCodeAt(i++);
enc1=chr1 >> 2;
enc2=((chr1 & 3) << 4) | (chr2 >> 4);
enc3=((chr2 & 15) << 2) | (chr3 >> 6);
enc4=chr3 & 63;
if (isNaN(chr2)) enc3=enc4=64;
else if (isNaN(chr3)) enc4=64;
out+=keyStr.charAt(enc1)+keyStr.charAt(enc2)+keyStr.charAt(enc3)+keyStr.charAt(enc4);
chr1=chr2=chr3=enc1=enc2=enc3=enc4="";
}
return out;
},
decodeBase64: function(input) {
var out="";
var chr1,chr2,chr3;
var enc1,enc2,enc3,enc4;
var i = 0;
// remove all characters that are not A-Z, a-z, 0-9, +, /, or =
input=input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
do {
enc1=keyStr.indexOf(input.charAt(i++));
enc2=keyStr.indexOf(input.charAt(i++));
enc3=keyStr.indexOf(input.charAt(i++));
enc4=keyStr.indexOf(input.charAt(i++));
chr1=(enc1 << 2) | (enc2 >> 4);
chr2=((enc2 & 15) << 4) | (enc3 >> 2);
chr3=((enc3 & 3) << 6) | enc4;
out=out+String.fromCharCode(chr1);
if (enc3!=64) out=out+String.fromCharCode(chr2);
if (enc4!=64) out=out+String.fromCharCode(chr3);
} while (i<input.length);
return out;
},
//}}}
// // I/O functions
//{{{
readFile: // read local BINARY file data
function(filePath) {
if(!window.Components) { return null; }
try { netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect"); }
catch(e) { alert("access denied: "+filePath); return null; }
var file = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
try { file.initWithPath(filePath); } catch(e) { alert("cannot read file - invalid path: "+filePath); return null; }
if (!file.exists()) { alert("cannot read file - not found: "+filePath); return null; }
var inputStream = Components.classes["@mozilla.org/network/file-input-stream;1"].createInstance(Components.interfaces.nsIFileInputStream);
inputStream.init(file, 0x01, 00004, null);
var bInputStream = Components.classes["@mozilla.org/binaryinputstream;1"].createInstance(Components.interfaces.nsIBinaryInputStream);
bInputStream.setInputStream(inputStream);
return(bInputStream.readBytes(inputStream.available()));
},
//}}}
//{{{
writeFile:
function(filepath,data) {
// TBD: decode base64 and write BINARY data to specified local path/filename
return(false);
},
//}}}
//{{{
askForFilename: // for FF3 fixup
function(target) {
var msg=config.messages.selectFile;
if (target && target.title) msg=target.title; // use target field tooltip (if any) as dialog prompt text
// get local path for current document
var path=getLocalPath(document.location.href);
var p=path.lastIndexOf("/"); if (p==-1) p=path.lastIndexOf("\\"); // Unix or Windows
if (p!=-1) path=path.substr(0,p+1); // remove filename, leave trailing slash
var file=""
var result=window.mozAskForFilename(msg,path,file,true); // FF3 FIXUP ONLY
if (target && result.length) // set target field and trigger handling
{ target.value=result; target.onchange(); }
return result;
}
};
//}}}
//{{{
if (window.mozAskForFilename===undefined) { // also defined by CoreTweaks (for ticket #604)
window.mozAskForFilename=function(msg,path,file,mustExist) {
if(!window.Components) return false;
try {
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
var nsIFilePicker = window.Components.interfaces.nsIFilePicker;
var picker = Components.classes['@mozilla.org/filepicker;1'].createInstance(nsIFilePicker);
picker.init(window, msg, mustExist?nsIFilePicker.modeOpen:nsIFilePicker.modeSave);
var thispath = Components.classes['@mozilla.org/file/local;1'].createInstance(Components.interfaces.nsILocalFile);
thispath.initWithPath(path);
picker.displayDirectory=thispath;
picker.defaultExtension='';
picker.defaultString=file;
picker.appendFilters(nsIFilePicker.filterAll|nsIFilePicker.filterText|nsIFilePicker.filterHTML);
if (picker.show()!=nsIFilePicker.returnCancel)
var result=picker.file.persistentDescriptor;
}
catch(ex) { displayMessage(ex.toString()); }
return result;
}
}
//}}}
/***
|Name|AttachFilePluginFormatters|
|Source|http://www.TiddlyTools.com/#AttachFilePluginFormatters|
|Version|4.0.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1.3|
|Type|plugin|
|Description|run-time library for displaying attachment tiddlers|
Runtime processing for //rendering// attachment tiddlers created by [[AttachFilePlugin]]. Attachment tiddlers are tagged with<<tag attachment>>and contain binary file content (e.g., jpg, gif, pdf, mp3, etc.) that has been stored directly as base64 text-encoded data or can be loaded from external files stored on a local filesystem or remote web server. Note: after creating new attachment tiddlers, you can remove [[AttachFilePlugin]], as long as you retain //this// tiddler (so that images can be rendered later on).
!!!!!Formatters
<<<
This plugin extends the behavior of the following TiddlyWiki core "wikify()" formatters:
* embedded images: {{{[img[tooltip|image]]}}}
* linked embedded images: {{{[img[tooltip|image][link]]}}}
* external/"pretty" links: {{{[[label|link]]}}}
''Please refer to AttachFilePlugin (source: http://www.TiddlyTools.com/#AttachFilePlugin) for additional information.''
<<<
!!!!!Revisions
<<<
2009.10.10 [4.0.1] in fileExists(), check for IE to avoid hanging Chrome during startup
2009.06.04 [4.0.0] changed attachment storage format to use //sections// instead of embedded substring markers.
2008.01.08 [*.*.*] plugin size reduction: documentation moved to ...Info
2007.12.04 [*.*.*] update for TW2.3.0: replaced deprecated core functions, regexps, and macros
2007.10.29 [3.7.0] more code reduction: removed upload handling from AttachFilePlugin (saves ~7K!)
2007.10.28 [3.6.0] removed duplicate formatter code from AttachFilePlugin (saves ~10K!) and updated documentation accordingly. This plugin ([[AttachFilePluginFormatters]]) is now //''required''// in order to display attached images/binary files within tiddler content.
2006.05.20 [3.4.0] through 2007.03.01 [3.5.3] sync with AttachFilePlugin
2006.05.13 [3.2.0] created from AttachFilePlugin v3.2.0
<<<
!!!!!Code
***/
// // version
//{{{
version.extensions.AttachFilePluginFormatters= {major: 4, minor: 0, revision: 1, date: new Date(2009,10,10)};
//}}}
//{{{
if (config.macros.attach==undefined) config.macros.attach= { };
//}}}
//{{{
if (config.macros.attach.isAttachment==undefined) config.macros.attach.isAttachment=function (title) {
var tiddler = store.getTiddler(title);
if (tiddler==undefined || tiddler.tags==undefined) return false;
return (tiddler.tags.indexOf("attachment")!=-1);
}
//}}}
//{{{
// test for local file existence - returns true/false without visible error display
if (config.macros.attach.fileExists==undefined) config.macros.attach.fileExists=function(f) {
if(window.Components) { // MOZ
try { netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect"); }
catch(e) { return false; } // security access denied
var file = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
try { file.initWithPath(f); }
catch(e) { return false; } // invalid directory
return file.exists();
}
else if (config.browser.isIE) { // IE
var fso = new ActiveXObject("Scripting.FileSystemObject");
return fso.FileExists(f);
}
else return true; // other browsers: assume file exists
}
//}}}
//{{{
if (config.macros.attach.getAttachment==undefined) config.macros.attach.getAttachment=function(title) {
// extract embedded data, local and remote links (if any)
var text=store.getTiddlerText(title,'');
var embedded=store.getTiddlerText(title+'##data','').trim();
var locallink=store.getTiddlerText(title+'##file','').trim();
var remotelink=store.getTiddlerText(title+'##url','').trim();
// backward-compatibility for older attachments (pre 4.0.0)
var startmarker="---BEGIN_DATA---\n";
var endmarker="\n---END_DATA---";
var pos=0; var endpos=0;
if ((pos=text.indexOf(startmarker))!=-1 && (endpos=text.indexOf(endmarker))!=-1)
embedded="data:"+(text.substring(pos+startmarker.length,endpos)).replace(/\n/g,'');
if ((pos=text.indexOf("/%LOCAL_LINK%/"))!=-1)
locallink=text.substring(text.indexOf("|",pos)+1,text.indexOf("]]",pos));
if ((pos=text.indexOf("/%REMOTE_LINK%/"))!=-1)
remotelink=text.substring(text.indexOf("|",pos)+1,text.indexOf("]]",pos));
// if there is a data: URI defined (not supported by IE)
if (embedded.length && !config.browser.isIE) return embedded;
// document is being served remotely... use remote URL (if any) (avoids security alert)
if (remotelink.length && document.location.protocol!="file:")
return remotelink;
// local link only... return link without checking file existence (avoids security alert)
if (locallink.length && !remotelink.length)
return locallink;
// local link, check for file exist... use local link if found
if (locallink.length) {
locallink=locallink.replace(/^\.[\/\\]/,''); // strip leading './' or '.\' (if any)
if (this.fileExists(getLocalPath(locallink))) return locallink;
// maybe local link is relative... add path from current document and try again
var pathPrefix=document.location.href; // get current document path and trim off filename
var slashpos=pathPrefix.lastIndexOf("/"); if (slashpos==-1) slashpos=pathPrefix.lastIndexOf("\\");
if (slashpos!=-1 && slashpos!=pathPrefix.length-1) pathPrefix=pathPrefix.substr(0,slashpos+1);
if (this.fileExists(getLocalPath(pathPrefix+locallink))) return locallink;
}
// no embedded data, no local (or not found), fallback to remote URL (if any)
if (remotelink.length) return remotelink;
// attachment URL doesn't resolve, just return input as is
return title;
}
//}}}
//{{{
if (config.macros.attach.init_formatters==undefined) config.macros.attach.init_formatters=function() {
if (this.initialized) return;
// find the formatter for "image" and replace the handler
for (var i=0; i<config.formatters.length && config.formatters[i].name!="image"; i++);
if (i<config.formatters.length) config.formatters[i].handler=function(w) {
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source)
if(lookaheadMatch && lookaheadMatch.index == w.matchStart) // Simple bracketted link
{
var e = w.output;
if(lookaheadMatch[5])
{
var link = lookaheadMatch[5];
// ELS -------------
var external=config.formatterHelpers.isExternalLink(link);
if (external)
{
if (config.macros.attach.isAttachment(link))
{
e = createExternalLink(w.output,link);
e.href=config.macros.attach.getAttachment(link);
e.title = config.macros.attach.linkTooltip + link;
}
else
e = createExternalLink(w.output,link);
}
else
e = createTiddlyLink(w.output,link,false,null,w.isStatic);
// ELS -------------
addClass(e,"imageLink");
}
var img = createTiddlyElement(e,"img");
if(lookaheadMatch[1])
img.align = "left";
else if(lookaheadMatch[2])
img.align = "right";
if(lookaheadMatch[3])
img.title = lookaheadMatch[3];
img.src = lookaheadMatch[4];
// ELS -------------
if (config.macros.attach.isAttachment(lookaheadMatch[4]))
img.src=config.macros.attach.getAttachment(lookaheadMatch[4]);
// ELS -------------
w.nextMatch = this.lookaheadRegExp.lastIndex;
}
}
//}}}
//{{{
// find the formatter for "prettyLink" and replace the handler
for (var i=0; i<config.formatters.length && config.formatters[i].name!="prettyLink"; i++);
if (i<config.formatters.length) {
config.formatters[i].handler=function(w) {
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source);
if(lookaheadMatch && lookaheadMatch.index == w.matchStart) {
var e;
var text = lookaheadMatch[1];
if(lookaheadMatch[3]) {
// Pretty bracketted link
var link = lookaheadMatch[3];
if (config.macros.attach.isAttachment(link)) {
e = createExternalLink(w.output,link);
e.href=config.macros.attach.getAttachment(link);
e.title=config.macros.attach.linkTooltip+link;
}
else e = (!lookaheadMatch[2] && config.formatterHelpers.isExternalLink(link))
? createExternalLink(w.output,link)
: createTiddlyLink(w.output,link,false,null,w.isStatic);
} else {
e = createTiddlyLink(w.output,text,false,null,w.isStatic);
}
createTiddlyText(e,text);
w.nextMatch = this.lookaheadRegExp.lastIndex;
}
}
} // if "prettyLink" formatter found
this.initialized=true;
}
//}}}
//{{{
config.macros.attach.init_formatters(); // load time init
//}}}
//{{{
if (TiddlyWiki.prototype.coreGetRecursiveTiddlerText==undefined) {
TiddlyWiki.prototype.coreGetRecursiveTiddlerText = TiddlyWiki.prototype.getRecursiveTiddlerText;
TiddlyWiki.prototype.getRecursiveTiddlerText = function(title,defaultText,depth) {
return config.macros.attach.isAttachment(title)?
config.macros.attach.getAttachment(title):this.coreGetRecursiveTiddlerText.apply(this,arguments);
}
}
//}}}
<<myComment>>
----
~~:::::__Fri Jun 25 2010 21:33:01 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Hide base64 encoded data in !data section.
EditFile:AttachFilePlugin
{{{
tiddlerFormat: '!usage\n{{{%0}}}\n%0\n!notes\n%1\n!type\n%2\n!file\n%3\n!url\n%4\n!hiddenData\n/\u0025\n!data\n%5\n!endHiddenData\n\u0025/',
}}}
----
~~:::::__Fri Jun 25 2010 21:34:45 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Added help message to differentiate linking or embedding.
{{{
if(useData) displayMessage('attached "'+title+'"');
else displayMessage('linked"'+title+'"');
}}}
/***
|Name|BugMeNotExitingPlugin|
|Source|http://cooltool.tiddlyspot.com#BugMeNotExitingPlugin|
|Documentation||
|Version|0.01|
|Author|Kenny Z|
|License|Plubic Domain|
|~CoreVersion|2.6|
|Type|plugin|
|Description|Disable confirm exit|
!Description:
Exit quickly without being bugged.
!Usage:
#Import
#Save and reload
!Code:
***/
//{{{
function confirmExit(){
hadConfirmExit = true;
return;
};
//}}}
/***
''Name:'' CalendarPlugin
''Version:'' <<getversion calendar>> (<<getversiondate calendar "DD MMM YYYY">>)
''Author:'' SteveRumsby
''Configuration:''
|''First day of week:''|<<option txtCalFirstDay>>|(Monday = 0, Sunday = 6)|
|''First day of weekend:''|<<option txtCalStartOfWeekend>>|(Monday = 0, Sunday = 6)|
''Syntax:''
|{{{<<calendar>>}}}|Produce a full-year calendar for the current year|
|{{{<<calendar year>>}}}|Produce a full-year calendar for the given year|
|{{{<<calendar year month>>}}}|Produce a one-month calendar for the given month and year|
|{{{<<calendar thismonth>>}}}|Produce a one-month calendar for the current month|
|{{{<<calendar lastmonth>>}}}|Produce a one-month calendar for last month|
|{{{<<calendar nextmonth>>}}}|Produce a one-month calendar for next month|
***/
// //Modify this section to change the text displayed for the month and day names, to a different language for example. You can also change the format of the tiddler names linked to from each date, and the colours used.
// // ''[[Changes]] by ELS 2005.10.30:''
// // config.macros.calendar.handler()
// // ^^use "tbody" element for IE compatibility^^
// // ^^IE returns 2005 for current year, FF returns 105... fix year adjustment accordingly^^
// // createCalendarDays()
// // ^^use showDate() function (if defined) to render autostyled date with linked popup^^
// // calendar stylesheet definition
// // ^^use .calendar class-specific selectors, add text centering and margin settings^^
//{{{
config.macros.calendar = {};
config.macros.calendar.monthnames = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"];
config.macros.calendar.daynames = ["M", "T", "W", "T", "F", "S", "S"];
config.macros.calendar.weekendbg = "#c0c0c0";
config.macros.calendar.monthbg = "#e0e0e0";
config.macros.calendar.holidaybg = "#ffc0c0";
//}}}
// //''Code section:''
// (you should not need to alter anything below here)//
//{{{
if(config.options.txtCalFirstDay == undefined)
config.options.txtCalFirstDay = 0;
if(config.options.txtCalStartOfWeekend == undefined)
config.options.txtCalStartOfWeekend = 5;
config.macros.calendar.tiddlerformat = "0DD/0MM/YYYY"; // This used to be changeable - for now, it isn't// <<smiley :-(>>
version.extensions.calendar = { major: 0, minor: 6, revision: 0, date: new Date(2006, 1, 22)};
config.macros.calendar.monthdays = [ 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
config.macros.calendar.holidays = [ ]; // Not sure this is required anymore - use reminders instead
//}}}
// //Is the given date a holiday?
//{{{
function calendarIsHoliday(date)
{
var longHoliday = date.formatString("0DD/0MM/YYYY");
var shortHoliday = date.formatString("0DD/0MM");
for(var i = 0; i < config.macros.calendar.holidays.length; i++) {
if(config.macros.calendar.holidays[i] == longHoliday || config.macros.calendar.holidays[i] == shortHoliday) {
return true;
}
}
return false;
}
//}}}
// //The main entry point - the macro handler.
// //Decide what sort of calendar we are creating (month or year, and which month or year)
// // Create the main calendar container and pass that to sub-ordinate functions to create the structure.
// ELS 2005.10.30: added creation and use of "tbody" for IE compatibility and fixup for year >1900//
// ELS 2005.10.30: fix year calculation for IE's getYear() function (which returns '2005' instead of '105')//
//{{{
config.macros.calendar.handler = function(place,macroName,params)
{
//alert("handle");
var calendar = createTiddlyElement(place, "table", null, "calendar", null);
var tbody = createTiddlyElement(calendar, "tbody", null, null, null);
var today = new Date();
var year = today.getYear();
if (year<1900) year+=1900;
if (params[0] == "thismonth")
{
cacheReminders(new Date(year, today.getMonth(), 1, 0, 0), 31);
createCalendarOneMonth(tbody, year, today.getMonth());
}
else if (params[0] == "lastmonth") {
var month = today.getMonth()-1; if (month==-1) { month=11; year--; }
cacheReminders(new Date(year, month, 1, 0, 0), 31);
createCalendarOneMonth(tbody, year, month);
}
else if (params[0] == "nextmonth") {
var month = today.getMonth()+1; if (month>11) { month=0; year++; }
cacheReminders(new Date(year, month, 1, 0, 0), 31);
createCalendarOneMonth(tbody, year, month);
}
else {
if (params[0]) year = params[0];
if(params[1])
{
cacheReminders(new Date(year, params[1]-1, 1, 0, 0), 31);
createCalendarOneMonth(tbody, year, params[1]-1);
}
else
{
cacheReminders(new Date(year, 0, 1, 0, 0), 366);
createCalendarYear(tbody, year);
}
}
window.reminderCacheForCalendar = null;
}
//}}}
//{{{
//This global variable is used to store reminders that have been cached
//while the calendar is being rendered. It will be renulled after the calendar is fully rendered.
window.reminderCacheForCalendar = null;
//}}}
//{{{
function cacheReminders(date, leadtime)
{
//alert("reminder");
if (window.findTiddlersWithReminders == null)
return;
window.reminderCacheForCalendar = {};
var leadtimeHash = [];
leadtimeHash [0] = 0;
leadtimeHash [1] = leadtime;
var t = findTiddlersWithReminders(date, leadtimeHash, null, 1);
for(var i = 0; i < t.length; i++) {
//just tag it in the cache, so that when we're drawing days, we can bold this one.
window.reminderCacheForCalendar[t[i]["matchedDate"]] = "reminder:" + t[i]["params"]["title"];
}
}
//}}}
//{{{
function createCalendarOneMonth(calendar, year, mon)
{
var row = createTiddlyElement(calendar, "tr", null, null, null);
createCalendarMonthHeader(calendar, row, config.macros.calendar.monthnames[mon] + " " + year, true, year, mon);
row = createTiddlyElement(calendar, "tr", null, null, null);
createCalendarDayHeader(row, 1);
createCalendarDayRowsSingle(calendar, year, mon);
}
//}}}
//{{{
function createCalendarMonth(calendar, year, mon)
{
var row = createTiddlyElement(calendar, "tr", null, null, null);
createCalendarMonthHeader(calendar, row, config.macros.calendar.monthnames[mon] + " " + year, false, year, mon);
row = createTiddlyElement(calendar, "tr", null, null, null);
createCalendarDayHeader(row, 1);
createCalendarDayRowsSingle(calendar, year, mon);
}
//}}}
//{{{
function createCalendarYear(calendar, year)
{
var row;
row = createTiddlyElement(calendar, "tr", null, null, null);
var back = createTiddlyElement(row, "td", null, null, null);
var backHandler = function() {
removeChildren(calendar);
createCalendarYear(calendar, year-1);
};
createTiddlyButton(back, "<", "Previous year", backHandler);
back.align = "center";
var yearHeader = createTiddlyElement(row, "td", null, "calendarYear", year);
yearHeader.align = "center";
yearHeader.setAttribute("colSpan", 19);
var fwd = createTiddlyElement(row, "td", null, null, null);
var fwdHandler = function() {
removeChildren(calendar);
createCalendarYear(calendar, year+1);
};
createTiddlyButton(fwd, ">", "Next year", fwdHandler);
fwd.align = "center";
createCalendarMonthRow(calendar, year, 0);
createCalendarMonthRow(calendar, year, 3);
createCalendarMonthRow(calendar, year, 6);
createCalendarMonthRow(calendar, year, 9);
}
//}}}
//{{{
function createCalendarMonthRow(cal, year, mon)
{
var row = createTiddlyElement(cal, "tr", null, null, null);
createCalendarMonthHeader(cal, row, config.macros.calendar.monthnames[mon], false, year, mon);
createCalendarMonthHeader(cal, row, config.macros.calendar.monthnames[mon+1], false, year, mon);
createCalendarMonthHeader(cal, row, config.macros.calendar.monthnames[mon+2], false, year, mon);
row = createTiddlyElement(cal, "tr", null, null, null);
createCalendarDayHeader(row, 3);
createCalendarDayRows(cal, year, mon);
}
//}}}
//{{{
function createCalendarMonthHeader(cal, row, name, nav, year, mon)
{
var month;
if(nav) {
var back = createTiddlyElement(row, "td", null, null, null);
back.align = "center";
back.style.background = config.macros.calendar.monthbg;
/*
back.setAttribute("colSpan", 2);
var backYearHandler = function() {
var newyear = year-1;
removeChildren(cal);
cacheReminders(new Date(newyear, mon , 1, 0, 0), 31);
createCalendarOneMonth(cal, newyear, mon);
};
createTiddlyButton(back, "<<", "Previous year", backYearHandler);
*/
var backMonHandler = function() {
var newyear = year;
var newmon = mon-1;
if(newmon == -1) { newmon = 11; newyear = newyear-1;}
removeChildren(cal);
cacheReminders(new Date(newyear, newmon , 1, 0, 0), 31);
createCalendarOneMonth(cal, newyear, newmon);
};
createTiddlyButton(back, "<", "Previous month", backMonHandler);
month = createTiddlyElement(row, "td", null, "calendarMonthname", name)
// month.setAttribute("colSpan", 3);
month.setAttribute("colSpan", 5);
var fwd = createTiddlyElement(row, "td", null, null, null);
fwd.align = "center";
fwd.style.background = config.macros.calendar.monthbg;
// fwd.setAttribute("colSpan", 2);
var fwdMonHandler = function() {
var newyear = year;
var newmon = mon+1;
if(newmon == 12) { newmon = 0; newyear = newyear+1;}
removeChildren(cal);
cacheReminders(new Date(newyear, newmon , 1, 0, 0), 31);
createCalendarOneMonth(cal, newyear, newmon);
};
createTiddlyButton(fwd, ">", "Next month", fwdMonHandler);
/*
var fwdYear = createTiddlyElement(row, "td", null, null, null);
var fwdYearHandler = function() {
var newyear = year+1;
removeChildren(cal);
cacheReminders(new Date(newyear, mon , 1, 0, 0), 31);
createCalendarOneMonth(cal, newyear, mon);
};
createTiddlyButton(fwd, ">>", "Next year", fwdYearHandler);
*/
} else {
month = createTiddlyElement(row, "td", null, "calendarMonthname", name)
month.setAttribute("colSpan", 7);
}
month.align = "center";
month.style.background = config.macros.calendar.monthbg;
}
//}}}
//{{{
function createCalendarDayHeader(row, num)
{
//alert("createCalendarDayHeader");
var cell;
for(var i = 0; i < num; i++) {
for(var j = 0; j < 7; j++) {
var d = j + (config.options.txtCalFirstDay - 0);
if(d > 6) d = d - 7;
cell = createTiddlyElement(row, "td", null, null, config.macros.calendar.daynames[d]);
if(d == (config.options.txtCalStartOfWeekend-0) || d == (config.options.txtCalStartOfWeekend-0+1))
cell.style.background = config.macros.calendar.weekendbg;
}
}
}
//}}}
//{{{
function createCalendarDays(row, col, first, max, year, mon)
{
//alert("createCalendarDays");
var i;
for(i = 0; i < col; i++) {
createTiddlyElement(row, "td", null, null, null);
}
var day = first;
for(i = col; i < 7; i++) {
var d = i + (config.options.txtCalFirstDay - 0);
if(d > 6) d = d - 7;
var daycell = createTiddlyElement(row, "td", null, null, null);
var isaWeekend = ((d == (config.options.txtCalStartOfWeekend-0) || d == (config.options.txtCalStartOfWeekend-0+1))? true:false);
if(day > 0 && day <= max) {
var celldate = new Date(year, mon, day);
// ELS 2005.10.30: use <<date>> macro's showDate() function to create popup
if (window.showDate) {
showDate(daycell,celldate,"popup","DD","DD-MMM-YYYY",true, isaWeekend);
} else {
if(isaWeekend) daycell.style.background = config.macros.calendar.weekendbg;
var title = celldate.formatString(config.macros.calendar.tiddlerformat);
if(calendarIsHoliday(celldate)) {
daycell.style.background = config.macros.calendar.holidaybg;
}
if(window.findTiddlersWithReminders == null) {
var link = createTiddlyLink(daycell, title, false);
link.appendChild(document.createTextNode(day));
} else {
var button = createTiddlyButton(daycell, day, title, onClickCalendarDate);
}
}
}
day++;
}
}
//}}}
// //We've clicked on a day in a calendar - create a suitable pop-up of options.
// //The pop-up should contain:
// // * a link to create a new entry for that date
// // * a link to create a new reminder for that date
// // * an <hr>
// // * the list of reminders for that date
//{{{
function onClickCalendarDate(e)
{
//alert("onClickCalendarDate");
// var button = this;
// var date = button.getAttribute("title");
// var dat = new Date(date.substr(6,4), date.substr(3,2)-1, date.substr(0, 2));
// date = dat.formatString(config.macros.calendar.tiddlerformat);
//var popup = createTiddlerPopup(this);
// popup.appendChild(document.createTextNode(date));
// var newReminder = function() {
// var t = store.getTiddlers(date);
// displayTiddler(null, date, 2, null, null, false, false);
// if(t) {
// document.getElementById("editorBody" + date).value += "\n<<reminder day:" + dat.getDate() +
// " month:" + (dat.getMonth()+1) +
// " year:" + (dat.getYear()+1900) + " title: >>";
// } else {
// document.getElementById("editorBody" + date).value = "<<reminder day:" + dat.getDate() +
// " month:" + (dat.getMonth()+1) +
// " year:" + (dat.getYear()+1900) + " title: >>";
// }
// };
// var link = createTiddlyButton(popup, "New reminder", null, newReminder);
// popup.appendChild(document.createElement("hr"));
// var t = findTiddlersWithReminders(dat, [0,14], null, 1);
// for(var i = 0; i < t.length; i++) {
// link = createTiddlyLink(popup, t[i].tiddler, false);
// link.appendChild(document.createTextNode(t[i].tiddler));
// }
}
//}}}
//{{{
function calendarMaxDays(year, mon)
{
//alert("calendarMaxDays");
var max = config.macros.calendar.monthdays[mon];
if(mon == 1 && (year % 4) == 0 && ((year % 100) != 0 || (year % 400) == 0)) {
max++;
}
return max;
}
//}}}
//{{{
function createCalendarDayRows(cal, year, mon)
{
//alert("createCalendarDayRows");
var row = createTiddlyElement(cal, "tr", null, null, null);
var first1 = (new Date(year, mon, 1)).getDay() -1 - (config.options.txtCalFirstDay-0);
if(first1 < 0) first1 = first1 + 7;
var day1 = -first1 + 1;
var first2 = (new Date(year, mon+1, 1)).getDay() -1 - (config.options.txtCalFirstDay-0);
if(first2 < 0) first2 = first2 + 7;
var day2 = -first2 + 1;
var first3 = (new Date(year, mon+2, 1)).getDay() -1 - (config.options.txtCalFirstDay-0);
if(first3 < 0) first3 = first3 + 7;
var day3 = -first3 + 1;
var max1 = calendarMaxDays(year, mon);
var max2 = calendarMaxDays(year, mon+1);
var max3 = calendarMaxDays(year, mon+2);
while(day1 <= max1 || day2 <= max2 || day3 <= max3) {
row = createTiddlyElement(cal, "tr", null, null, null);
createCalendarDays(row, 0, day1, max1, year, mon); day1 += 7;
createCalendarDays(row, 0, day2, max2, year, mon+1); day2 += 7;
createCalendarDays(row, 0, day3, max3, year, mon+2); day3 += 7;
}
}
//}}}
//{{{
function createCalendarDayRowsSingle(cal, year, mon)
{
//alert("createCalendar");
var row = createTiddlyElement(cal, "tr", null, null, null);
var first1 = (new Date(year, mon, 1)).getDay() -1 - (config.options.txtCalFirstDay-0);
if(first1 < 0) first1 = first1+ 7;
var day1 = -first1 + 1;
var max1 = calendarMaxDays(year, mon);
while(day1 <= max1) {
row = createTiddlyElement(cal, "tr", null, null, null);
createCalendarDays(row, 0, day1, max1, year, mon); day1 += 7;
}
}
//}}}
// //ELS 2005.10.30: added styles
//{{{
setStylesheet(".calendar, .calendar table, .calendar th, .calendar tr, .calendar td { font-size:10pt; text-align:center; } .calendar, .calendar a { margin:0px !important; padding:0px !important; }", "calendarStyles");
//}}}
/***
|''Name:''|ClearChangeCountPlugin|
|''Description:''|Adds a button to toolbar or sync menu to clear the change count|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#ClearChangeCountPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Beta|
|''Date:''|June 20, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description:
Adds a button to toolbar or sync menu to clear the change count. Useful for clearing out distractions during syncing.
[img[clearChangeCount.png]]
!!Usage:
#Import
#Save and reload
//Optionally, add "clearChangeCount" to [[ToolbarCommands]]//
!!Code:
***/
//{{{
originalSyncing = config.commands.syncing.handlePopup;
config.commands.syncing.handlePopup = function(popup,title) {
originalSyncing(popup,title);
var btn = createTiddlyButton(createTiddlyElement(popup,"li"),
config.commands.clearChangeCount.text,
config.commands.clearChangeCount.tooltip,
config.commands.clearChangeCount.handler);
btn.setAttribute("title",title);
};
// toolbar - add this to [[ToolbarCommands]]
config.commands.clearChangeCount = {
text: "clearChangeCount",
tooltip: "Clears the change count",
handler: function(event,src,title){
if(!title) title = this.getAttribute("title");
store.resetTiddler(title);
autoSaveChanges();
}
};
//}}}
<<myComment>>
Comment of: [[ClearChangeCountPlugin]]
----
~~:::::__Sat Jun 26 2010 14:20:40 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ added autosave check
/***
!! Collapse Plugins
folds and unfolds tiddlers.
***/
///%
config.commands.toggleTiddler = {
text: " ▲ ",
tooltip: "Toggle this tiddler",
handler: function(event,src,title)
{
var e = story.findContainingTiddler(src);
if(e.getAttribute("template") != config.tiddlerTemplates[DEFAULT_EDIT_TEMPLATE]){
var template;
if(e.getAttribute("template") != "CollapsedTemplate" ){
config.commands.toggleTiddler.text=" ▼ ";
e.setAttribute("oldTemplate",e.getAttribute("template"));
story.displayTiddler(null,title,"CollapsedTemplate");
}
else{
config.commands.toggleTiddler.text=" ▲ ";
var e = story.findContainingTiddler(src);
story.displayTiddler(null,title,e.getAttribute("oldTemplate"));
}
}
}
}
config.macros.toggleAll = {
handler: function(place,macroName,params,wikifier,paramString,tiddler){
createTiddlyButton(place,"toggle all","",function(){
story.forEachTiddler(function(title,tiddler){
config.commands.toggleTiddler.handler(null,tiddler,title);
}
)})
}
}
config.commands.collapseOthers = {
text: "collapse others",
tooltip: "Expand this tiddler and collapse all others",
handler: function(event,src,title)
{
var e = story.findContainingTiddler(src);
story.forEachTiddler(function(title,tiddler){
if(tiddler.getAttribute("template") != config.tiddlerTemplates[DEFAULT_EDIT_TEMPLATE]){
var t="CollapsedTemplate";
if (e==tiddler) t=e.getAttribute("oldTemplate");
if (!t||!t.length){
t="ViewTemplate";
config.commands.toggleTiddler.text=" ▲ ";
}
else config.commands.toggleTiddler.text=" ▼ ";
story.displayTiddler(null,title,t);
}
})
}
}
config.macros.collapseAll = {
handler: function(place,macroName,params,wikifier,paramString,tiddler){
createTiddlyButton(place,"collapse all","",function(){
story.forEachTiddler(function(title,tiddler){
if(tiddler.getAttribute("template") != config.tiddlerTemplates[DEFAULT_EDIT_TEMPLATE]){
config.commands.toggleTiddler.text=" ▼ ";
story.displayTiddler(null,title,"CollapsedTemplate");
}
})})
}
}
config.macros.expandAll = {
handler: function(place,macroName,params,wikifier,paramString,tiddler){
createTiddlyButton(place,"expand all","",function(){
story.forEachTiddler(function(title,tiddler){
if(tiddler.getAttribute("template") == "CollapsedTemplate"){
config.commands.toggleTiddler.text=" ▲ ";
story.displayTiddler(null,title,tiddler.getAttribute("oldTemplate"));
}
})})
}
}
//%/
<<myComment>>
----
~~:::::__Sat Jun 26 2010 00:06:21 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Change: Instead of close or open, I made it toggle.
<!--{{{-->
<span class='title' macro='view title'></span>
<span 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>)</span>
<div>
<span class='toolbar' macro='toolbar [[ToolbarCommands::ViewToolbar]]'></span>
<span class='toolbar' macro='tagger'></span>
<div class='toolbar' macro='toolbar toggleTiddler'></div>
</div>
<!--}}}-->
<<newTiddler
label:"New Ticket"
title:"title_comment"
focus:"text"
tag:"comment" tag:"excludeLists"
text:""
>>
#<<newTiddler label:"e" prompt:"edit" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" prompt:"view" title:"title_comment" template:"ViewTemplate">><<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">>
#<<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">><<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">>
#<<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">><<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">>
#<<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">><<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">>
#<<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">><<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">>
#<<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">><<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">>
#<<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">><<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">>
#<<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">><<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">>
#<<slider chkCookieSlider title_comment "Help I can't get it to work and it's driving me crazy!!" "Read more...">><<newTiddler label:"e" title:"title_comment" focus:"text" tag:"comment" tag:"excludeLists">><<newTiddler label:"v" title:"title_comment" template:"ViewTemplate">>
[[!!!Help I can't get it to work and it's driving me crazy!!|title_comment]] ~<<slider chkCookieSlider title_comment "Read more..." "Read more...">>
Help I can't get it to work and it's driving me crazy!! ~<<slider chkCookieSlider title_comment "Read more..." "Read more...">>
!!!!Help I can't get it to work and it's driving me crazy!!
adsdasfadsffds<<tiddler title_comment>><<foldHeadings closed>>
!!!!Help I can't get it to work and it's driving me crazy!!
sdfdf sf sdfas sdfs fd hfd g h 5e yt yu r 6 u 6 43 52343243 5 43 534 5 45765 8 73 6345 34535
4 35325 3 5 35 32 45 345 3 5 36 65 7 47 35 73 57 4 6 rjh gyj gn g mn gdh j ythu y 45 6 46 e t tr jytj <<foldHeadings closed>>
!!!!Help I can't get it to work and it's driving me crazy!!
sdfdf sf sdfas sdfs fd hfd g h 5e yt yu r 6 u 6 43 52343243 5 43 534 5 45765 8 73 6345 34535
4 35325 3 5 35 32 45 345 3 5 36 65 7 47 35 73 57 4 6 rjh gyj gn g mn gdh j ythu y 45 6 46 e t tr jytj <<foldHeadings closed>>
/***
|''Name:''|CopyPlugin|
|''Description:''|Copy a tiddler. For backup, etc...|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#CopyPlugin|
|''CodeRepository:''||
|''Version:''|0.0.1|
|''Status:''|beta|
|''Date:''|June 25, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Makes a copy of a tiddler. For backup, etc...
!!Usage
Add "{{{basicCopy}}}" to [[ToolbarCommands]] in the ~ViewToolbar slice.
<<<
|click|copy|
|ctrl+click|copy & display|
<<<
!!Code
***/
//{{{
if(!version.extensions.basicCopy) {
version.extensions.basicCopy= {installed:true};
config.commands.basicCopy= {
text: "copy",
tooltip: "Copy this tiddler to another tiddler",
readOnlyText: '',
readOnlyTooltip: '',
warning: '',
handler: function(event,src,title) {
des = prompt("Enter name for tiddler title:",title+"_copy");
if(!des.replace(/^\s+|\s+$/g,'')) return;
if(store.tiddlerExists(des)){
displayMessage('Fail: "'+des+'" already exists.');
return;
}
t = store.getTiddler(title);
store.saveTiddler(null,des,t.text,config.options.txtUserName,
(new Date()),t.tags.slice(0),(cooltool.core.clone(t.fields)),true,t.created);
if (t.tags.contains("systemConfig"))store.setTiddlerTag( des,1,"systemConfigDisable" );
autoSaveChanges();
if(event.ctrlKey) story.displayTiddler(null,des);
displayMessage('Success: "'+title+'" copied to "'+des+'".');
},
};
if(!window.cooltool) window.cooltool={};
if(!cooltool.core) cooltool.core={};
if(!cooltool.core.clone)
cooltool.core.clone = function(o){ //IF RENAMING, REM. THIS IS A RECURSIVE FUNCTION
if(!o||typeof(o)!='object')return o;
var t = new o.constructor();
for(var k in o) t[k] = cooltool.core.clone(o[k]); // RECURSIVE
return t;
};
} //# end of 'install only once'
//}}}
<<myComment>>
Comment of: [[CopyPlugin]]
----
~~:::::__Sat Jun 26 2010 14:17:34 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ added autosave check
----
~~:::::__Sun Jun 27 2010 00:44:00 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Changes: modifier and modified date are updated and not duplicates of the old ones.
----
~~:::::__Sun Jun 27 2010 00:51:21 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ I found it annoying having the copy displayed while I was only trying to make a backup. Not only that, I end up making changes to the duplicate instead. So I'm changing it to ctrl + click for the tiddler to display.
----
~~:::::__Sun Jun 27 2010 00:57:38 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ added: if tag=="systemConfig", add "systemConfigDisable"
/***
!String callback function
***/
//{{{
function strCB(str){
return str;
};
//}}}
/***
!new window
__Parameters__
*obj
*maxLevel,
*maxStringLength,
*boolSkipMethodsAndFunctions,
*separator
*startLevel???,
*strCallback
***/
//{{{
//debug(document.location);
function debug(content,level, sMax, skipMethods, sep, l, strCallback) {
if(!level) level = 3;
top.console=window.open('','myconsole','width=600,height=800'
+',menubar=0'+',toolbar=1'+',status=0'+',scrollbars=1'+',resizable=1')
top.console.document.writeln(
'<html><head><title>Console</title></head>'
+'<body bgcolor=white onLoad="self.focus()">'
+print_r(content,level,sMax, skipMethods, sep, l, strCallback)+'</body></html>'
)
top.console.document.close()
}
//}}}
/***
!print_r
*added strCallback for string manipulations.
***/
//{{{
//print_r( obj, maxLevel, maxStringLength, boolSkipMethodsAndFunctions, separator, startLevel???, strCallback )
function print_r(x, max, sMax, skipMethods, sep, l, strCallback) {
max = max || 10;
sMax = sMax || 50;
skipMethods = skipMethods || true;
sep = sep || ' ';
l = l || 0;
if (l > max) return '<font color=\'green\'>[Stopped at ' + l + ' levels]</font><br>\n';
var i, r = '', t = typeof x, tab = '';
if (x === null)
r += '(null)<br>\n';
else if (t == 'object') {
l++;
for (i = 0; i < l; i++)
tab += sep;
if (x && x.length)
t = 'array';
r += '(' + t + ':' + l + ') : <br>\n';
for (i in x) {
if (!(typeof x[i] == 'function' && skipMethods)) {
try {
r += tab + '[' + i + '] : ' +
print_r(x[i], max, sMax, skipMethods, sep, l, strCallback);
}
catch (e) {
return r+='<font color=\'red\'>[ERROR: ' + e + ']</font><br>\n';
}
}
}
}
else {
var sLen = '';
if (t == 'string') {
sLen = '[' + x.length + ']';
if (x.length > sMax)
x = x.substr(0, sMax) + '...';
if(strCallback)
x = strCallback(x);
}
if (!(t == 'function' && skipMethods)) {
r += '(' + t + sLen + ') ' + x + '<br>\n';
}
}
return r + '<hr />';
};
//}}}
//{{{
if (window.location.protocol == "http:"){
Story.prototype.displayDefaultTiddlers = function(){
this.displayTiddlers(null,store.filterTiddlers("[GettingStarted] [historyPluginSample] [Samples]"));
};
config.options.txtUserName="Guest";
}
//}}}
/***
|''Name:''|DeliciousTaggingPlugin|
|''Version:''|0.1|
|''Source''|http://jackparke.googlepages.com/jtw.html#DeliciousTaggingPlugin ([[del.icio.us|http://del.icio.us/post?url=http://jackparke.googlepages.com/jtw.html%DeliciousTaggingPlugin]])|
|''Author:''|[[Jack]]|
!Description
Allows easy 'del.icio.us'-like tagging in the EditTemplate by showing all tags as a list of link-buttons.
!Usage
Replace your the editorFooter div in your [[EditTemplate]] with the following:
{{{
<div class='editorFooter' macro='deliciousTagging'></div>
}}}
!Code
***/
//{{{
version.extensions.deliciousTagging = {major: 0, minor: 1, revision: 0, date: new Date("June 11, 2007")};
config.macros.deliciousTagging= {};
config.macros.deliciousTagging.onTagClick = function(e)
{
if(!e) var e = window.event;
var tag = this.getAttribute("tag");
var title = this.getAttribute("tiddler");
if(!readOnly)
story.setTiddlerTag(title,tag,0);
return false;
};
config.macros.deliciousTagging.handler = function(place,macroName,params,wikifier,paramString,tiddler)
{
if(tiddler instanceof Tiddler) {
var title = tiddler.title;
if(!e) var e = window.event;
var tags = store.getTags();
var lingo = config.views.editor.tagChooser;
for(var t=0; t<tags.length; t++) {
var theTag = createTiddlyButton(place,tags[t][0],lingo.tagTooltip.format([tags[t][0]]),config.macros.deliciousTagging.onTagClick);
theTag.setAttribute("tag",tags[t][0]);
theTag.setAttribute("tiddler",tiddler.title);
place.appendChild(document.createTextNode(" "));
}
}
};
//}}}
/***
|''Name:''|DisableStrikeThroughPlugin|
|''Description:''|Allows you to disable TiddlyWiki's automatic linking of WikiWords|
|''Author:''|Martin Budden (mjbudden (at) gmail (dot) com)|
|''Source:''|http://www.martinswiki.com/#DisableStrikeThroughPlugin |
|''CodeRepository:''|http://svn.tiddlywiki.org/Trunk/contributors/MartinBudden/plugins/DisableStrikeThroughPlugin.js |
|''Version:''|0.0.1|
|''Date:''|Feb 18, 2008|
|''Comments:''|Please make comments at http://groups.google.co.uk/group/TiddlyWikiDev |
|''License:''|[[Creative Commons Attribution-ShareAlike 2.5 License|http://creativecommons.org/licenses/by-sa/2.5/]] |
|''~CoreVersion:''|2.1.0|
***/
//{{{
// Ensure that the DisableStrikeThroughPlugin is only installed once.
if(!version.extensions.DisableStrikeThroughPlugin) {
version.extensions.DisableStrikeThroughPlugin = {installed:true};
if(version.major < 2 || (version.major == 2 && version.minor < 1))
{alertAndThrow('DisableStrikeThroughPlugin requires TiddlyWiki 2.1 or newer.');}
DisableStrikeThroughPlugin = {};
DisableStrikeThroughPlugin.replaceFormatters = function()
{
for(var i=0; i<config.formatters.length; i++) {
var name = config.formatters[i].name;
if(name == 'characterFormat') {
config.formatters[i].match = "''|//|__|\\^\\^|~~|\\{\\{\\{";
break;
} else if(name == 'strikeByChar') {
config.formatters.splice(i,1);
break;
}
}
};
DisableStrikeThroughPlugin.replaceFormatters();
} // end of 'install only once'
//}}}
/***
|''Name:''|DisableWikiLinksPlugin|
|''Description:''|Allows you to disable TiddlyWiki's automatic linking of WikiWords|
|''Author:''|Martin Budden (mjbudden (at) gmail (dot) com)|
|''Source:''|http://www.martinswiki.com/#DisableWikiLinksPlugin |
|''CodeRepository:''|http://svn.tiddlywiki.org/Trunk/contributors/MartinBudden/plugins/DisableWikiLinksPlugin.js |
|''Version:''|0.1.3|
|''Date:''|Aug 5, 2006|
|''Comments:''|Please make comments at http://groups.google.co.uk/group/TiddlyWikiDev |
|''License:''|[[Creative Commons Attribution-ShareAlike 2.5 License|http://creativecommons.org/licenses/by-sa/2.5/]] |
|''~CoreVersion:''|2.1.0|
|''Disable WikiLinks''|<<option chkDisableWikiLinks>>|
!My change:
*added description for chkDisableWikiLinks
*defaults to true;
!Code
***/
//{{{
// Ensure that the DisableWikiLinksPlugin is only installed once.
if(!version.extensions.DisableWikiLinksPlugin) {
version.extensions.DisableWikiLinksPlugin = {installed:true};
if(version.major < 2 || (version.major == 2 && version.minor < 1))
{alertAndThrow('DisableWikiLinksPlugin requires TiddlyWiki 2.1 or newer.');}
merge(config.optionsDesc, {chkDisableWikiLinks:"Disables auto ~WikiLinks"}); //for "advanced options" section
if (config.options.chkDisableWikiLinks==undefined)
{config.options.chkDisableWikiLinks = true;} //default
Tiddler.prototype.autoLinkWikiWords = function()
{
if(config.options.chkDisableWikiLinks==true)
{return false;}
return !this.isTagged('systemConfig') && !this.isTagged('excludeMissing');
};
} // end of 'install only once'
//}}}
// Copyright (c) 2008 Tony Garnock-Jones <tonyg@lshift.net>
// Copyright (c) 2008 LShift Ltd. <query@lshift.net>
//
// Permission is hereby granted, free of charge, to any person
// obtaining a copy of this software and associated documentation files
// (the "Software"), to deal in the Software without restriction,
// including without limitation the rights to use, copy, modify, merge,
// publish, distribute, sublicense, and/or sell copies of the Software,
// and to permit persons to whom the Software is furnished to do so,
// subject to the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
// BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
DrawDvcs = {
renderRepository: function (repo) {
var childCount = {};
var ordering = [];
var i, j, item, parent, column, row;
var worklist = repo.childlessRevisions();
while (worklist.length) {
item = worklist.shift();
ordering.push(item);
var parents = repo.lookupParents(item);
for (i = 0; i < parents.length; i++) {
parent = parents[i];
if (childCount[parent] == undefined) {
childCount[parent] = (repo.children[parent] || []).length;
}
childCount[parent] = childCount[parent] - 1;
if (childCount[parent] === 0) {
worklist.push(parent);
}
}
}
var slots = [];
var assignments = {};
function allocateSlot(item) {
var column = assignments[item];
if (typeof(column) != 'number') {
column = null;
for (var j = 0; j < slots.length; j++) {
if (slots[j] === null) {
column = j;
break;
}
}
if (column === null) {
slots.push(item);
column = slots.length - 1;
}
}
return column;
}
var finalAssignments = [];
var cells = [];
var oldrow = [];
for (i = 0; i < ordering.length; i++) {
item = ordering[i];
var hasKid = typeof(assignments[item]) == 'number';
column = allocateSlot(item);
var parentIds = repo.lookupParents(item);
var parentColumns = [];
slots[column] = null;
for (j = 0; j < parentIds.length; j++) {
parent = parentIds[j];
var c2 = (j === 0)
? (typeof(assignments[parent]) == 'number'
? allocateSlot(parent)
: column)
: allocateSlot(parent);
parentColumns.push(c2);
slots[c2] = parent;
assignments[parent] = c2;
}
finalAssignments.push(column);
row = [];
for (j = 0; j < slots.length; j++) {
var oldCell = (oldrow.length >= j ? oldrow[j] : 0);
if (oldCell & 16) {
row[j] = (oldCell & 4) ? 1 : 0;
} else {
row[j] = (oldCell & (1 | 4 | 8)) ? 1 : 0;
}
}
row[column] = 16 | (hasKid ? 1 : 0);
for (j = 0; j < parentColumns.length; j++) {
var parentColumn = parentColumns[j];
var n1 = Math.min(parentColumn, column) + 1;
var n2 = Math.max(parentColumn, column);
for (var k = n1; k < n2; k++) {
row[k] = row[k] | 2;
}
if (parentColumn == column) {
row[parentColumn] = row[parentColumn] | 4;
} else {
row[parentColumn] = row[parentColumn] | (column > parentColumn ? 8 : 4);
row[column] = row[column] | (column > parentColumn ? 2 : 8);
}
}
cells.push(row);
oldrow = row;
}
var results = [];
for (i = 0; i < ordering.length; i++) {
item = ordering[i];
column = finalAssignments[i];
row = cells[i];
var result = {revId: item, pictures: []};
for (j = 0; j < row.length; j++) {
var v = row[j];
result.pictures.push((v & 16 ? "blob_" : "stick_") + (v & 15) + ".png");
}
results.push(result);
}
return results;
},
simpleRenderRepository: function (repo) {
var ordering = DrawDvcs.renderRepository(repo);
var html = "";
for (var i = 0; i < ordering.length; i++) {
var item = ordering[i];
var rev = repo.lookupRev(item.revId);
var pictures = item.pictures;
for (var j = 0; j < pictures.length; j++) {
html = html + "<img src='img/" + pictures[j] + "' />";
}
html = html+" "+item.revId+" ("+rev.branch+") "+(rev.metadata||{}).summary+"<br />\n";
}
return "<p style='line-height: 0px; white-space: nowrap;'>" + html + "</p>";
}
};
/***
|!Name:| ''@@font-size(large):font-variant(small-caps):~EchoMacro@@'' |
|!Version:|1.0.0|
|!Location|http://gwsyzygy.googlepages.com/creator.html#EchoMacro|
|!Author:|GregWalker |
|!Type:|Macro Debugging Tool |
|!Requires|~TW2.x|
!Description
<<<
''echo'' will echo back all params passed to it, including each parameter's #, type, value, and //literal// value (unwikified). Useful for debugging exactly what is getting passed to a macro.
<<<
!Examples
|!Source|!Output|h
|{{{<<echo "Hello, World">>}}}|<<echo "Hello, World">>|
|{{{<<echo this and "that" and [[the other]]>>}}}|<<echo this and "that" and [[the other]]>>|
!History
* 23-Mar-06, version 1.0.0, initial version
!~ToDo
* Update to new //enhanced// parameters in 2.0.7
!Code
***/
/*{{{*/
version.extensions.EchoMacro = { major: 1, minor: 0, revision: 0, date: new Date(2006,3,23),
source: "http://gwsyzygy.googlepages.com/creator.html#EchoMacro"
};
config.macros.echo = {};
config.macros.echo.handler = function (place,macroName,params,wikifier,paramString,tiddler) {
if (params.length == 0)
wikify("//no params//",place);
for(var i=0; i<params.length; i++)
{
wikify("params[" + i + "] (" + typeof(params[i]) + ") = '" + params[i] + "' {{{[" + (params[i] ? params[i].toString() : "null" ) + "]}}}\n", place);
}
}
/*}}}*/
//This plugin is released under the [[Creative Commons Attribution 2.5 License|http://creativecommons.org/licenses/by/2.5/]]
/***
|Name|EditSectionPlugin|
|Source|http://www.TiddlyTools.com/#EditSectionPlugin|
|Documentation|http://www.TiddlyTools.com/#EditSectionPlugin|
|Version|1.0.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Requires|StickyPopupPlugin|
|Description|invoke popup 'section editor' for specified section of a tiddler|
!!!!!Usage
<<<
{{{
<<editSection TiddlerName##sectionname label tooltip>>
}}}
where:
* ''~TiddlerName##sectionname'' specifies the section you want to edit.
** If you omit the "~TiddlerName##" portion (i.e., only enter "sectionname"), the current containing tiddler is assumed.
** Changing the section name in the popup editor //renames// that section within the tiddler.
** Changing the tiddler title in the popup editor //copies// that section to another tiddler.
** If the indicated tiddler and/or section does not yet exist, it will be created when you press 'save'.
* ''label'' and ''tooltip'' (both //optional//) specify the link label and mouseover help text for the 'edit section' command link.
<<<
!!!!!Sample
<<<
This is a sample section for you to try
<<<
!!!!!Example
<<<
{{{
<<editSection Sample>>
}}}
<<editSection Sample>>
<<<
!!!!!Configuration
<<<
To customize and/or translate the HTML form layout used to render the section editor, edit the [[EditSectionPluginPanel]] shadow tiddler.
<<<
!!!!!Revisions
<<<
2010.05.24 [1.0.2] in save(), escape regexp chars in section titles (e.g. "!SectionNameWith?InIt")
2009.09.07 [1.0.1] documentation/code cleanup
2009.09.01 [1.0.0] initial release
<<<
!!!!!Code
***/
//{{{
version.extensions.EditSectionPlugin= {major: 1, minor: 0, revision: 2, date: new Date(2010,5,24)};
// deliver shadow payload
config.shadowTiddlers.EditSectionPluginPanel=store.getTiddlerText('EditSectionPlugin##html');
config.macros.editSection = {
label: 'edit section...',
tip: 'edit %0',
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var here=story.findContainingTiddler(place);
var tid=params[0];
var label=params[1]||this.label.format([tid]);
var tip=params[2]||this.tip.format([tid]);
var btn=createTiddlyButton(place,label,tip,this.click);
btn.setAttribute('tid',tid);
},
click: function(event) {
var here=story.findContainingTiddler(this);
var parts=this.getAttribute('tid').split('##');
var title=parts[1]?parts[0]:null;
var section=parts[1]||parts[0];
if (!title&&here)
title=here.getAttribute('tiddler');
if (!title||!section) {
displayMessage('invalid section reference: '+this.getAttribute('tid'));
return false;
}
return config.macros.editSection.popup(this,event,title,section);
},
popup: function(here,event,title,section) {
var p=Popup.create(here); if (!p) return false;
p.className+=' smallform editSectionPopup sticky';
p.innerHTML=store.getTiddlerText('EditSectionPluginPanel');
var f=p.getElementsByTagName('form')[0];
f.title.value=title;
f.section.value=section;
f.newsection.value=title+'##'+section;
f.content.value=store.getTiddlerText(title+'##'+section,'');
if (version.extensions.TextAreaPlugin) new window.TextAreaResizer(f.content);
Popup.show();
event.cancelBubble=true;
if(event.stopPropagation)event.stopPropagation();
return false;
},
save: function(here,event) {
var f=here.form;
var parts=f.newsection.value.split('##');
var title=parts[1]?parts[0]:null;
var section=parts[1]||parts[0];
var where=Popup.stack[Popup.stack.length-1].root;
if (!title) title=story.findContainingTiddler(where).getAttribute('tiddler');
if (!title||!section) {
displayMessage('invalid section reference: '+f.newsection.value);
f.newsection.focus(); f.newsection.select(); return false;
}
var t=store.getTiddler(title);
if (!t) {
if (!confirm("The tiddler: '"+title+"' does not exist. Press OK to create it."))
{ f.newsection.focus(); f.newsection.select(); return false; }
t=new Tiddler(); t.title=title; t.text='!'+section+'\n';
}
var oldsection=f.section.value;
var current=store.getTiddlerText(title+'##'+oldsection,''); // current content
var pattern=new RegExp('(.*!{1,6})'
+oldsection.escapeRegExp()+'\\n'
+current.escapeRegExp()
+'((?:\\n!{1,6}|$).*)'); // replace
var revised='$1'+section+'\n'+f.content.value+'$2'; // new content
var who =t&&config.options.chkForceMinorUpdate?t.modifier:config.options.txtUserName;
var when=t&&config.options.chkForceMinorUpdate?t.modified:new Date();
store.saveTiddler(title,title,t.text.replace(pattern,revised),who,when,t.tags,t.fields);
story.refreshTiddler(title,null,true);
Popup.remove();
return false;
}
}
//}}}
/***
!!!!!html
<!--{{{-->
<form style="white-space:nowrap">
<input type="hidden" name="title" value="">
<input type="hidden" name="section" value="">
<input type="text" name="newsection" value="" style="width:68%"><!--
--><input type=button value="save" style="width:15%"
onclick="return config.macros.editSection.save(this,event)"><!--
--><input type=button value="cancel" style="width:15%"
onclick="Popup.remove(); return false;">
<div class="editor"><textarea name="content" rows="10" cols="60" style="border:0"
onfocus="this.select()"></textarea></div>
</form>
<!--}}}-->
!!!!!end
***/
<!--{{{-->
<form style="white-space:nowrap">
<input type="hidden" name="title" value="" /><input type="hidden" name="section" value="" />
<input type="text" name="newsection" value="" style="width:25em" />
<input type=button value="save" style="width:4em" onclick="return(config.macros.editSection.save(this,event))" />
<input type=button value="cancel" style="width:4em" onclick="Popup.remove(); return false;" /><br />
<textarea name="content" rows="10" cols="60" style="border:0;width:50%"></textarea>
</form>
<!--}}}-->
<!--{{{-->
<div class='toolbar' macro='toolbar +saveTiddler -cancelTiddler deleteTiddler'></div>
<div class="title" macro="view title"></div>
<table style="border:0px; width:100%;">
<tr><td><div class="editLabel">Title</div></td><td><div style="padding-right:1em;" class="editor" macro="edit title"></div></td></tr>
<tr><td><div class="editLabel">Tags</div></td><td><div style="padding-right:1em;" class="editor" macro="edit tags"></div></td></tr>
<tr><td></td><td>
<div class="editorFooter"><span macro="message views.editor.tagPrompt"></span><span macro="tagChooser"></span>
</div><div macro='annotations'></div></td></tr></table>
<div class="editor" macro="edit text"></div>
<!-- <span macro='autosizeEditor'></span> -->
<span macro='resizeEditor'></span><br /><br />
<!--}}}-->
!usage
{{{[img[EmbeddedHiddenData.png]]}}}
[img[EmbeddedHiddenData.png]]
!notes
attached by FileDropPlugin
!type
image/png
!file
!url
!hiddenData
/%
!data

!endHiddenData
%/
/***
|''Name:''|ExampleAdaptorPlugin|
|''Description:''|Example Adaptor which can be used as a basis for creating a new Adaptor|
|''Author:''|Martin Budden (mjbudden (at) gmail (dot) com)|
|''Source:''|http://www.martinswiki.com/#ExampleAdaptorPlugin|
|''CodeRepository:''|http://svn.tiddlywiki.org/Trunk/contributors/MartinBudden/adaptors/ExampleAdaptorPlugin.js|
|''Version:''|0.5.3|
|''Status:''|Not for release - this is a template for creating new adaptors|
|''Date:''|Mar 11, 2007|
|''Comments:''|Please make comments at http://groups.google.co.uk/group/TiddlyWikiDev|
|''License:''|[[Creative Commons Attribution-ShareAlike 2.5 License|http://creativecommons.org/licenses/by-sa/2.5/]]|
|''~CoreVersion:''|2.2.0|
To make this example into a real TiddlyWiki adaptor, you need to:
# Globally search and replace ExampleAdpator with the name of your adaptor
# Delete any functionality not supported by you host (for example, putTiddler may not be supported)
# Do the actions indicated by the !!TODO comments, namely:
## Set the values of the main variables, eg ExampleAdaptor.serverType etc
## Fill in the uri templates in the .prototype functions
## Parse the responseText returned in the Callback functions and put the results in the appropriate variables
***/
//{{{
if(!version.extensions.ExampleAdaptorPlugin) {
version.extensions.ExampleAdaptorPlugin = {installed:true};
function ExampleAdaptor()
{
this.host = null;
this.workspace = null;
return this;
}
// !!TODO set the variables below
ExampleAdaptor.mimeType = 'text/x.';
ExampleAdaptor.serverType = 'example'; // MUST BE LOWER CASE
ExampleAdaptor.serverParsingErrorMessage = "Error parsing result from server";
ExampleAdaptor.errorInFunctionMessage = "Error in function ExampleAdaptor.%0";
ExampleAdaptor.prototype.setContext = function(context,userParams,callback)
{
if(!context) context = {};
context.userParams = userParams;
if(callback) context.callback = callback;
context.adaptor = this;
if(!context.host)
context.host = this.host;
context.host = ExampleAdaptor.fullHostName(context.host);
if(!context.workspace)
context.workspace = this.workspace;
return context;
};
ExampleAdaptor.doHttpGET = function(uri,callback,params,headers,data,contentType,username,password)
{
return doHttp('GET',uri,data,contentType,username,password,callback,params,headers);
};
ExampleAdaptor.doHttpPOST = function(uri,callback,params,headers,data,contentType,username,password)
{
return doHttp('POST',uri,data,contentType,username,password,callback,params,headers);
};
ExampleAdaptor.fullHostName = function(host)
{
if(!host)
return '';
if(!host.match(/:\/\//))
host = 'http://' + host;
if(host.substr(host.length-1) != '/')
host = host + '/';
return host;
};
ExampleAdaptor.minHostName = function(host)
{
return host ? host.replace(/^http:\/\//,'').replace(/\/$/,'') : '';
};
// Convert a page title to the normalized form used in uris
ExampleAdaptor.normalizedTitle = function(title)
{
var n = title.toLowerCase();
n = n.replace(/\s/g,'_').replace(/\//g,'_').replace(/\./g,'_').replace(/:/g,'').replace(/\?/g,'');
if(n.charAt(0)=='_')
n = n.substr(1);
return String(n);
};
// Convert a date in YYYY-MM-DD hh:mm format into a JavaScript Date object
ExampleAdaptor.dateFromEditTime = function(editTime)
{
var dt = editTime;
return new Date(Date.UTC(dt.substr(0,4),dt.substr(5,2)-1,dt.substr(8,2),dt.substr(11,2),dt.substr(14,2)));
};
ExampleAdaptor.prototype.openHost = function(host,context,userParams,callback)
{
this.host = ExampleAdaptor.fullHostName(host);
context = this.setContext(context,userParams,callback);
if(context.callback) {
context.status = true;
window.setTimeout(function() {callback(context,userParams);},0);
}
return true;
};
ExampleAdaptor.prototype.openWorkspace = function(workspace,context,userParams,callback)
{
this.workspace = workspace;
context = this.setContext(context,userParams,callback);
if(context.callback) {
context.status = true;
window.setTimeout(function() {callback(context,userParams);},0);
}
return true;
};
ExampleAdaptor.prototype.getWorkspaceList = function(context,userParams,callback)
{
context = this.setContext(context,userParams,callback);
// !!TODO set the uriTemplate
var uriTemplate = '%0';
var uri = uriTemplate.format([context.host]);
var req = ExampleAdaptor.doHttpGET(uri,ExampleAdaptor.getWorkspaceListCallback,context);
return typeof req == 'string' ? req : true;
};
ExampleAdaptor.getWorkspaceListCallback = function(status,context,responseText,uri,xhr)
{
context.status = false;
context.statusText = ExampleAdaptor.errorInFunctionMessage.format(['getWorkspaceListCallback']);
if(status) {
try {
// !!TODO: parse the responseText here
var list = [];
var item = {
title:'exampleTitle',
name:'exampleName'
};
list.push(item);
} catch (ex) {
context.statusText = exceptionText(ex,ExampleAdaptor.serverParsingErrorMessage);
if(context.callback)
context.callback(context,context.userParams);
return;
}
context.workspaces = list;
context.status = true;
} else {
context.statusText = xhr.statusText;
}
if(context.callback)
context.callback(context,context.userParams);
};
ExampleAdaptor.prototype.getTiddlerList = function(context,userParams,callback)
{
context = this.setContext(context,userParams,callback);
// !!TODO set the uriTemplate
var uriTemplate = '%0%1';
var uri = uriTemplate.format([context.host,context.workspace]);
var req = ExampleAdaptor.doHttpGET(uri,ExampleAdaptor.getTiddlerListCallback,context);
return typeof req == 'string' ? req : true;
};
ExampleAdaptor.getTiddlerListCallback = function(status,context,responseText,uri,xhr)
{
context.status = false;
context.statusText = ExampleAdaptor.errorInFunctionMessage.format(['getTiddlerListCallback']);
if(status) {
try {
// !!TODO: parse the responseText here
var list = [];
var tiddler = new Tiddler('example');
list.push(tiddler);
} catch (ex) {
context.statusText = exceptionText(ex,ExampleAdaptor.serverParsingErrorMessage);
if(context.callback)
context.callback(context,context.userParams);
return;
}
context.tiddlers = list;
context.status = true;
} else {
context.statusText = xhr.statusText;
}
if(context.callback)
context.callback(context,context.userParams);
};
ExampleAdaptor.prototype.generateTiddlerInfo = function(tiddler)
{
var info = {};
var host = this && this.host ? this.host : ExampleAdaptor.fullHostName(tiddler.fields['server.host']);
var workspace = this && this.workspace ? this.workspace : tiddler.fields['server.workspace'];
// !!TODO set the uriTemplate
uriTemplate = '%0%1%2';
info.uri = uriTemplate.format([host,workspace,tiddler.title]);
return info;
};
ExampleAdaptor.prototype.getTiddlerRevision = function(title,revision,context,userParams,callback)
{
context = this.setContext(context,userParams,callback);
if(revision)
context.revision = revision;
return this.getTiddler(title,context,userParams,callback);
};
ExampleAdaptor.prototype.getTiddler = function(title,context,userParams,callback)
{
context = this.setContext(context,userParams,callback);
if(title)
context.title = title;
if(context.revision) {
// !!TODO set the uriTemplate
var uriTemplate = '%0%1%2%3';
} else {
// !!TODO set the uriTemplate
uriTemplate = '%0%1%2';
}
uri = uriTemplate.format([context.host,context.workspace,ExampleAdaptor.normalizedTitle(title),context.revision]);
context.tiddler = new Tiddler(title);
context.tiddler.fields.wikiformat = 'exampleformat';
context.tiddler.fields['server.type'] = ExampleAdaptor.serverType;
context.tiddler.fields['server.host'] = ExampleAdaptor.minHostName(context.host);
context.tiddler.fields['server.workspace'] = context.workspace;
var req = ExampleAdaptor.doHttpGET(uri,ExampleAdaptor.getTiddlerCallback,context);
return typeof req == 'string' ? req : true;
};
ExampleAdaptor.getTiddlerCallback = function(status,context,responseText,uri,xhr)
{
context.status = false;
context.statusText = ExampleAdaptor.errorInFunctionMessage.format(['getTiddlerCallback']);
if(status) {
try {
// !!TODO: parse the responseText here
// !!TODO: fill in tiddler fields as available
//context.tiddler.tags = ;
//context.tiddler.fields['server.page.id'] = ;
//context.tiddler.fields['server.page.name'] = ;
//context.tiddler.fields['server.page.revision'] = String(...);
//context.tiddler.modifier = ;
//context.tiddler.modified = ExampleAdaptor.dateFromEditTime(...);
} catch (ex) {
context.statusText = exceptionText(ex,ExampleAdaptor.serverParsingErrorMessage);
if(context.callback)
context.callback(context,context.userParams);
return;
}
context.status = true;
} else {
context.statusText = xhr.statusText;
if(context.callback)
context.callback(context,context.userParams);
return;
}
if(context.callback)
context.callback(context,context.userParams);
};
ExampleAdaptor.prototype.getTiddlerRevisionList = function(title,limit,context,userParams,callback)
{
context = this.setContext(context,userParams,callback);
// !!TODO set the uriTemplate
var uriTemplate = '%0%1%2';
if(!limit)
limit = 10;
var uri = uriTemplate.format([context.host,context.workspace,ExampleAdaptor.normalizedTitle(title),limit]);
var req = ExampleAdaptor.doHttpGET(uri,ExampleAdaptor.getTiddlerRevisionListCallback,context);
return typeof req == 'string' ? req : true;
};
ExampleAdaptor.getTiddlerRevisionListCallback = function(status,context,responseText,uri,xhr)
{
context.status = false;
if(status) {
var content = null;
try {
// !!TODO: parse the responseText here
var list = [];
var tiddler = new Tiddler('example');
// !!TODO: fill in tiddler fields as available
//tiddler.modified = ExampleAdaptor.dateFromEditTime();
//tiddler.modifier = ;
//tiddler.tags = ;
//tiddler.fields['server.page.id'] = ;
//tiddler.fields['server.page.name'] = ;
//tiddler.fields['server.page.revision'] = ;
list.push(tiddler);
} catch (ex) {
context.statusText = exceptionText(ex,ExampleAdaptor.serverParsingErrorMessage);
if(context.callback)
context.callback(context,context.userParams);
return;
}
var sortField = 'server.page.revision';
list.sort(function(a,b) {return a.fields[sortField] < b.fields[sortField] ? +1 : (a.fields[sortField] == b.fields[sortField] ? 0 : -1);});
context.revisions = list;
context.status = true;
} else {
context.statusText = xhr.statusText;
}
if(context.callback)
context.callback(context,context.userParams);
};
ExampleAdaptor.prototype.putTiddler = function(tiddler,context,userParams,callback)
{
context = this.setContext(context,userParams,callback);
context.title = tiddler.title;
// !!TODO set the uriTemplate
var uriTemplate = '%0%1%2';
var host = context.host ? context.host : ExampleAdaptor.fullHostName(tiddler.fields['server.host']);
var workspace = context.workspace ? context.workspace : tiddler.fields['server.workspace'];
var uri = uriTemplate.format([host,workspace,tiddler.title,tiddler.text]);
var req = ExampleAdaptor.doHttpPOST(uri,ExampleAdaptor.putTiddlerCallback,context,{"X-Http-Method": "PUT"},tiddler.text,ExampleAdaptor.mimeType);
return typeof req == 'string' ? req : true;
};
ExampleAdaptor.putTiddlerCallback = function(status,context,responseText,uri,xhr)
{
if(status) {
context.status = true;
} else {
context.status = false;
context.statusText = xhr.statusText;
}
if(context.callback)
context.callback(context,context.userParams);
};
ExampleAdaptor.prototype.close = function()
{
return true;
};
config.adaptors[ExampleAdaptor.serverType] = ExampleAdaptor;
} //# end of 'install only once'
//}}}
/***
|''Name:''|ExampleFormatterPlugin|
|''Description:''|Example Formatter which can be used as a basis for creating a new Formatter. Allows Tiddlers to use [[example|http://www.example.com/wikitext]] text formatting|
|''Author:''|Martin Budden (mjbudden (at) gmail (dot) com)|
|''Source:''|http://www.martinswiki.com/#ExampleFormatterPlugin |
|''CodeRepository:''|http://svn.tiddlywiki.org/Trunk/contributors/MartinBudden/formatters/ExampleFormatterPlugin.js |
|''Version:''|0.1.10|
|''Status:''|Not for release - this is a template for creating new formatters|
|''Date:''|Nov 5, 2006|
|''Comments:''|Please make comments at http://groups.google.co.uk/group/TiddlyWikiDev |
|''License:''|[[Creative Commons Attribution-ShareAlike 2.5 License|http://creativecommons.org/licenses/by-sa/2.5/]] |
|''~CoreVersion:''|2.1.0|
To make this example into a real TiddlyWiki formatter, you need to:
# Globally search and replace ExampleAdpator with the name of your formatter
# Remove any format entries that are not required
# Change the existing format entries as required
# Add any new format entries that are required
***/
//{{{
// Ensure that the ExampleFormatterPlugin is only installed once.
if(!version.extensions.ExampleFormatterPlugin) {
version.extensions.ExampleFormatterPlugin = {installed:true};
if(version.major < 2 || (version.major == 2 && version.minor < 1))
{alertAndThrow('ExampleFormatterPlugin requires TiddlyWiki 2.1 or later.');}
exampleFormatter = {}; // 'namespace' for local functions
exampleDebug = function(out,str)
{
createTiddlyText(out,str.replace(/\n/mg,'\\n').replace(/\r/mg,'RR'));
createTiddlyElement(out,'br');
};
wikify = function(source,output,highlightRegExp,tiddler)
{
if(source && source !== '') {
var w = new Wikifier(source,getParser(tiddler),highlightRegExp,tiddler);
w.output = tiddler ? createTiddlyElement(output,'p') : output;
w.subWikifyUnterm(w.output);
}
};
config.formatterHelpers.setAttributesFromParams = function(e,p)
{
var re = /\s*(.*?)=(?:(?:"(.*?)")|(?:'(.*?)')|((?:\w|%|#)*))/mg;
var match = re.exec(p);
while(match) {
var s = match[1].unDash();
if(s=='bgcolor') {
s = 'backgroundColor';
}
try {
if(match[2]) {
e.setAttribute(s,match[2]);
} else if(match[3]) {
e.setAttribute(s,match[3]);
} else {
e.setAttribute(s,match[4]);
}
}
catch(ex) {}
match = re.exec(p);
}
};
config.exampleFormatters = [
{
name: 'exampleHeading',
match: '^={1,6}(?!=)',
termRegExp: /(={0,6} *\n+)/mg,
handler: function(w)
{
w.subWikifyTerm(createTiddlyElement(w.output,'h'+w.matchLength),this.termRegExp);
}
},
{
name: 'exampleList',
match: '^[\\*#;:]+ ',
lookaheadRegExp: /^([\*#;:])+ /mg,
termRegExp: /(\n)/mg,
handler: function(w)
{
var stack = [w.output];
var currLevel = 0, currType = null;
var listLevel, listType, itemType, baseType;
w.nextMatch = w.matchStart;
this.lookaheadRegExp.lastIndex = w.nextMatch;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source);
while(lookaheadMatch && lookaheadMatch.index == w.nextMatch) {
switch(lookaheadMatch[1]) {
case '*':
listType = 'ul';
itemType = 'li';
break;
case '#':
listType = 'ol';
itemType = 'li';
break;
case ';':
listType = 'dl';
itemType = 'dt';
break;
case ':':
listType = 'dl';
itemType = 'dd';
break;
default:
break;
}
if(!baseType)
baseType = listType;
listLevel = lookaheadMatch[0].length;
w.nextMatch += lookaheadMatch[0].length;
var t;
if(listLevel > currLevel) {
for(t=currLevel; t<listLevel; t++) {
var target = (currLevel == 0) ? stack[stack.length-1] : stack[stack.length-1].lastChild;
stack.push(createTiddlyElement(target,listType));
}
} else if(listType!=baseType && listLevel==1) {
w.nextMatch -= lookaheadMatch[0].length;
return;
} else if(listLevel < currLevel) {
for(t=currLevel; t>listLevel; t--)
stack.pop();
} else if(listLevel == currLevel && listType != currType) {
stack.pop();
stack.push(createTiddlyElement(stack[stack.length-1].lastChild,listType));
}
currLevel = listLevel;
currType = listType;
var e = createTiddlyElement(stack[stack.length-1],itemType);
w.subWikifyTerm(e,this.termRegExp);
this.lookaheadRegExp.lastIndex = w.nextMatch;
lookaheadMatch = this.lookaheadRegExp.exec(w.source);
}
}
},
{
name: 'exampleRule',
match: '^---+$\\n?',
handler: function(w)
{
createTiddlyElement(w.output,'hr');
}
},
{
name: 'macro',
match: '<<',
lookaheadRegExp: /<<([^>\s]+)(?:\s*)((?:[^>]|(?:>(?!>)))*)>>/mg,
handler: function(w)
{
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source);
if(lookaheadMatch && lookaheadMatch.index == w.matchStart && lookaheadMatch[1]) {
w.nextMatch = this.lookaheadRegExp.lastIndex;
invokeMacro(w.output,lookaheadMatch[1],lookaheadMatch[2],w,w.tiddler);
}
}
},
{
name: 'exampleExplicitLink',
match: '\\[\\[',
lookaheadRegExp: /\[\[(.*?)(?:\|(.*?))?\]\]/mg,
handler: function(w)
{
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source);
if(lookaheadMatch && lookaheadMatch.index == w.matchStart) {
var link = lookaheadMatch[1];
var text = lookaheadMatch[2] ? lookaheadMatch[2] : link;
var e = config.formatterHelpers.isExternalLink(link) ? createExternalLink(w.output,link) : createTiddlyLink(w.output,link,false,null,w.isStatic);
createTiddlyText(e,text);
w.nextMatch = this.lookaheadRegExp.lastIndex;
}
}
},
{
name: 'exampleNotWikiLink',
match: '!' + config.textPrimitives.wikiLink,
handler: function(w)
{
w.outputText(w.output,w.matchStart+1,w.nextMatch);
}
},
{
name: 'exampleWikiLink',
match: config.textPrimitives.wikiLink,
handler: function(w)
{
if(w.matchStart > 0) {
var preRegExp = new RegExp(config.textPrimitives.anyLetter,'mg');
preRegExp.lastIndex = w.matchStart-1;
var preMatch = preRegExp.exec(w.source);
if(preMatch.index == w.matchStart-1) {
w.outputText(w.output,w.matchStart,w.nextMatch);
return;
}
}
var output = w.output;
if(w.autoLinkWikiWords == true || store.isShadowTiddler(w.matchText)) {
output = createTiddlyLink(w.output,w.matchText,false,null,w.isStatic);
}
w.outputText(output,w.matchStart,w.nextMatch);
}
},
{
name: 'exampleUrlLink',
match: config.textPrimitives.urlPattern,
handler: function(w)
{
w.outputText(createExternalLink(w.output,w.matchText),w.matchStart,w.nextMatch);
}
},
{
name: 'exampleBold',
match: '\\*\\*',
termRegExp: /(\*\*|(?=\n\n))/mg,
element: 'strong',
handler: config.formatterHelpers.createElementAndWikify
},
{
name: 'exampleItalic',
match: '//',
termRegExp: /(\/\/|(?=\n\n))/mg,
element: 'em',
handler: config.formatterHelpers.createElementAndWikify
},
{
name: 'exampleUnderline',
match: '__',
termRegExp: /(__|(?=\n\n))/mg,
element: 'u',
handler: config.formatterHelpers.createElementAndWikify
},
{
name: 'exampleStrikeBy',
match: '--(?!\\s|$)',
termRegExp: /((?!\s)--|(?=\n\n))/mg,
element: 'strike',
handler: config.formatterHelpers.createElementAndWikify
},
{
name: 'exampleSuperscript',
match: '\\^\\^',
termRegExp: /(\^\^|(?=\n\n))/mg,
element: 'sup',
handler: config.formatterHelpers.createElementAndWikify
},
{
name: 'exampleSubscript',
match: '~~',
termRegExp: /(~~|(?=\n\n))/mg,
element: 'sub',
handler: config.formatterHelpers.createElementAndWikify
},
{
name: 'exampleMonospaced',
match: '\\{\\{\\{',
lookaheadRegExp: /\{\{\{((?:.|\n)*?)\}\}\}/mg,
element: 'code',
handler: config.formatterHelpers.enclosedTextHelper
},
{
name: 'exampleParagraph',
match: '\\n{2,}',
handler: function(w)
{
w.output = createTiddlyElement(w.output,'p');
}
},
{
name: 'exampleLineBreak',
match: '\\n|<br ?/?>',
handler: function(w)
{
createTiddlyElement(w.output,'br');
}
},
{
name: 'exampleComment',
match: '<!\\-\\-',
lookaheadRegExp: /<!\-\-((?:.|\n)*?)\-\-!>/mg,
handler: function(w)
{
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source);
if(lookaheadMatch && lookaheadMatch.index == w.matchStart) {
w.nextMatch = this.lookaheadRegExp.lastIndex;
}
}
},
{
name: 'exampleHtmlEntitiesEncoding',
match: '&#?[a-zA-Z0-9]{2,8};',
handler: function(w)
{
createTiddlyElement(w.output,'span').innerHTML = w.matchText;
}
},
{
name: "html",
match: "<[Hh][Tt][Mm][Ll]>",
lookaheadRegExp: /<[Hh][Tt][Mm][Ll]>((?:.|\n)*?)<\/[Hh][Tt][Mm][Ll]>/mg,
handler: function(w)
{
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source);
if(lookaheadMatch && lookaheadMatch.index == w.matchStart) {
createTiddlyElement(w.output,"span").innerHTML = lookaheadMatch[1];
w.nextMatch = this.lookaheadRegExp.lastIndex;
}
}
}
];
config.parsers.exampleFormatter = new Formatter(config.exampleFormatters);
config.parsers.exampleFormatter.format = 'example';
config.parsers.exampleFormatter.formatTag = 'ExampleFormat';
} // end of 'install only once'
//}}}
/***
|''Name:''|XXXXXXXXXXX|
|''Description:''|YYYYYYYYYYY|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#XXXXXXXXX|
|''Dependencies:''||
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|June 25, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
//!!TODO write a brief description of the plugin here//
!!Usage
#Import
#Save & Reload
!!Configuration
MSGMSGMSG: <<option txtXXXXXXX>>
<<option chkXXXXXX>> MSGMSGMSGMSGMSG
!!Code
***/
//{{{
//------------
// VERSION
//------------
if(!version.extensions.MyProgramName) {
version.extensions.MyProgramName= {installed:true};
/*
config.extensions: Plugins
config.macros: Macros
config.commands: Toolbar Commands
config.paramifiers: Paramifiers
config.formatters: Formatters
config.adaptors: Adaptors
*/
//-------------------
// COMMANDS
//-------------------
config.commands.COMMANDNAME = {
text: "TEXT",
tooltip: "TOOLTIP",
readOnlyText: "READ_ONLY_MODE",
readOnlyTooltip: "READ_ONLY_MODE",
warning: "???",
handler: function(event,src,title) {
// Code Here
return false;
},
};
// ------------------
// MACROS
// ------------------
config.macros.MACRONAME= {
init: function () {
// Startup Code Here
},
handler: function(place,macroName,params,wikifier,paramString,tiddler)
{
createTiddlyButton(place,"label","",function(){ /*CALLBACK*/ });
},
otherFunction: function(e){ },
};
} //# end of 'install only once'
//}}}
/***
|''Name:''|ExportCommandPlugin|
|''Description:''|Adds export button to the toolbar|
|''Requires:''|Exports raw. Requires ExportTiddlersPlugin for fancy exports|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#ExportCommandPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|June 29, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
|''Browser''|Firefox|
!!Description
Adds export button to the toolbar.
!!Usage
#Import
#Save & Reload
#Add "{{{exportTiddler}}}" to [[ToolbarCommands]] in the ~ViewToolbar slice.
Click on export command to export to default file.
Ctrl+click for a different filename.
!!Configuration
Default export filename: <<option txtDefaultExportFile>> <<option chkUseTitleForFileName>> Use tiddler's title as filename?
__Advanced Options Requiring ExportTiddlersPlugin__
<<option chkMergeExportTiddler>> Merge Mode. * //Disregard the overwrite warning from the ChooseFile dialog when merging.//
Filetype: <<option txtExportFileType>>
**ps: PureStore (no code)
**cs: comma-separated (CSV)
**nf: news feed (XML)
**tw: full TiddlyWiki
**tx: plain text
**raw: only the tiddler's text
!!Code
***/
//{{{
if(!version.extensions.ExportCommandPlugin) {
version.extensions.ExportCommandPlugin= {installed:true};
var co=config.options;
if(!co.chkMergeExportTiddler)co.chkMergeExportTiddler=true;
if(!co.txtExportFileType)co.txtExportFileType="ps";
if(!co.txtDefaultExportFile)co.txtDefaultExportFile="export.html"
if(!co.chkUseTitleForFileName)co.chkUseTitleForFileName=false;
config.commands.exportTiddler = {
text: "export",
tooltip: "Export this tiddler",
handler: function(event,src,title){
if (window.location.protocol!='file:'){ // make sure we are local
displayMessage(config.messages.notFileUrlError); return;
}
var target=this.getPath();
if(event.ctrlKey){
target=askForFilename(null,target,title,false);
}else if(co.chkUseTitleForFileName){
target+="export\\"+title+".html"; // safety folder.
}else{ //default
target+=co.txtDefaultExportFile;
}
//If tagged as attachment, find MIME type and base64Decode it.
var filetype=co.txtExportFileType.toLowerCase();
if(!version.extensions.ExportTiddlersPlugin||filetype=="raw"){ // if not installed.
saveFile(target, convertUnicodeToUTF8(store.getTiddlerText(title,''))); // save Raw
displayMessage(target+" exported raw.");
return;
}
// Pass off to ExportTiddlersPlugin
var cme=config.macros.exportTiddlers;
var merge=co.chkMergeExportTiddler;
var tids=[]; tids.push(store.getTiddler(title));
var out=cme.assembleFile(target,filetype,tids,"",{val:0},merge);
var link='file:///'+target.replace(/\\/g,'/');
if (link==decodeURIComponent(window.location.href)) return; //prevent overwrite
var ok=saveFile(target,out.replace(/\\/g,'/')); //unix
displayMessage((ok?cme.okmsg:cme.failmsg).format([1,'',target]),link);
},
getPath: function(){
var path=getLocalPath(document.location.href);
var p=path.lastIndexOf("/");
if (p==-1) p=path.lastIndexOf("\\"); // Windows
return path.substr(0,p+1);
},
};
if(!window.askForFilename){
function askForFilename(msg,path,file,mustExist) { //Ticket #604
if(window.Components)
var r=mozAskForFilename(msg,path,file,mustExist);
else if(config.browser.isIE)
var r=ieAskForFilename(msg,path,file,mustExist);
else
var r=prompt(msg,path+file)||""; // fallback
return r||"";
}
function mozAskForFilename(msg,path,file,mustExist) {
try {
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
var nsIFilePicker = window.Components.interfaces.nsIFilePicker;
var picker = Components.classes['@mozilla.org/filepicker;1'].createInstance(nsIFilePicker);
picker.init(window, msg,mustExist?nsiFilePicker.modeOpen:nsIFilePicker.modeSave);
var thispath = Components.classes['@mozilla.org/file/local;1'].createInstance(Components.interfaces.nsILocalFile);
thispath.initWithPath(path);
picker.displayDirectory=thispath;
picker.defaultExtension='html';
picker.defaultString=file;
picker.appendFilters(nsIFilePicker.filterAll|nsIFilePicker.filterText|nsIFilePicker.filterHTML);
if (picker.show()!=nsIFilePicker.returnCancel)
var result=picker.file.persistentDescriptor;
}
catch(e) {
alert('error during local file access: '+e.toString())
}
return result;
}
function ieAskForFilename(msg,path,file,mustExist) {
try {
var s = new ActiveXObject('UserAccounts.CommonDialog');
s.Filter='All files|*.*|Text files|*.txt|HTML files|*.htm;*.html|';
s.FilterIndex=3; // default to HTML files;
s.InitialDir=path;
s.FileName=file;
if (s.showOpen())
var result=s.FileName;
}
catch(e) {
var result=prompt(msg,path+file); // fallback for pre-XP/IE6
}
return result;
}
};
} //# end of 'install only once'
//}}}
/***
|Name|ExportTiddlersPlugin|
|Source|http://www.TiddlyTools.com/#ExportTiddlersPlugin|
|Documentation|http://www.TiddlyTools.com/#ExportTiddlersPluginInfo|
|Version|2.9.5|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|interactively select/export tiddlers to a separate file|
!!!!!Documentation
>see [[ExportTiddlersPluginInfo]]
!!!!!Inline control panel (live):
><<exportTiddlers inline>>
!!!!!Revisions
<<<
2010.02.25 2.9.5 added merge checkbox option and improved 'merge' status message
|please see [[ExportTiddlersPluginInfo]] for additional revision details|
2005.10.09 0.0.0 development started
<<<
!!!!!Code
***/
//{{{
// version
version.extensions.ExportTiddlersPlugin= {major: 2, minor: 9, revision: 5, date: new Date(2010,2,25)};
// default shadow definition
config.shadowTiddlers.ExportTiddlers='<<exportTiddlers inline>>';
// add 'export' backstage task (following built-in import task)
if (config.tasks) { // TW2.2 or above
config.tasks.exportTask = {
text:'export',
tooltip:'Export selected tiddlers to another file',
content:'<<exportTiddlers inline>>'
}
config.backstageTasks.splice(config.backstageTasks.indexOf('importTask')+1,0,'exportTask');
}
config.macros.exportTiddlers = {
$: function(id) { return document.getElementById(id); }, // abbreviation
label: 'export tiddlers',
prompt: 'Copy selected tiddlers to an export document',
okmsg: '%0 tiddler%1 written to %2',
failmsg: 'An error occurred while creating %1',
overwriteprompt: '%0\ncontains %1 tiddler%2 that will be discarded or replaced',
mergestatus: '%0 tiddler%1 added, %2 tiddler%3 updated, %4 tiddler%5 unchanged',
statusmsg: '%0 tiddler%1 - %2 selected for export',
newdefault: 'export.html',
datetimefmt: '0MM/0DD/YYYY 0hh:0mm:0ss', // for 'filter date/time' edit fields
type_TW: "tw", type_PS: "ps", type_TX: "tx", type_CS: "cs", type_NF: "nf", // file type tokens
type_map: { // maps type param to token values
tiddlywiki:"tw", tw:"tw", wiki: "tw",
purestore: "ps", ps:"ps", store:"ps",
plaintext: "tx", tx:"tx", text: "tx",
comma: "cs", cs:"cs", csv: "cs",
newsfeed: "nf", nf:"nf", xml: "nf", rss:"nf"
},
handler: function(place,macroName,params) {
if (params[0]!='inline')
{ createTiddlyButton(place,this.label,this.prompt,this.togglePanel); return; }
var panel=this.createPanel(place);
panel.style.position='static';
panel.style.display='block';
},
createPanel: function(place) {
var panel=this.$('exportPanel');
if (panel) { panel.parentNode.removeChild(panel); }
setStylesheet(store.getTiddlerText('ExportTiddlersPlugin##css',''),'exportTiddlers');
panel=createTiddlyElement(place,'span','exportPanel',null,null)
panel.innerHTML=store.getTiddlerText('ExportTiddlersPlugin##html','');
this.initFilter();
this.refreshList(0);
var fn=this.$('exportFilename');
if (window.location.protocol=='file:' && !fn.value.length) {
// get new target path/filename
var newPath=getLocalPath(window.location.href);
var slashpos=newPath.lastIndexOf('/'); if (slashpos==-1) slashpos=newPath.lastIndexOf('\\');
if (slashpos!=-1) newPath=newPath.substr(0,slashpos+1); // trim filename
fn.value=newPath+this.newdefault;
}
return panel;
},
togglePanel: function(e) { var e=e||window.event;
var cme=config.macros.exportTiddlers; // abbrev
var parent=resolveTarget(e).parentNode;
var panel=cme.$('exportPanel');
if (panel==undefined || panel.parentNode!=parent)
panel=cme.createPanel(parent);
var isOpen=panel.style.display=='block';
if(config.options.chkAnimate)
anim.startAnimating(new Slider(panel,!isOpen,e.shiftKey || e.altKey,'none'));
else
panel.style.display=isOpen?'none':'block' ;
if (panel.style.display!='none') {
cme.refreshList(0);
cme.$('exportFilename').focus();
cme.$('exportFilename').select();
}
e.cancelBubble = true; if (e.stopPropagation) e.stopPropagation(); return(false);
},
process: function(which) { // process panel control interactions
var theList=this.$('exportList'); if (!theList) return false;
var count = 0;
var total = store.getTiddlers('title').length;
switch (which.id) {
case 'exportFilter':
count=this.filterExportList();
var panel=this.$('exportFilterPanel');
if (count==-1) { panel.style.display='block'; break; }
this.$('exportStart').disabled=(count==0);
this.$('exportDelete').disabled=(count==0);
this.displayStatus(count,total);
if (count==0) { alert('No tiddlers were selected'); panel.style.display='block'; }
break;
case 'exportStart':
this.go();
break;
case 'exportDelete':
this.deleteTiddlers();
break;
case 'exportHideFilter':
case 'exportToggleFilter':
var panel=this.$('exportFilterPanel')
panel.style.display=(panel.style.display=='block')?'none':'block';
break;
case 'exportSelectChanges':
var lastmod=new Date(document.lastModified);
for (var t = 0; t < theList.options.length; t++) {
if (theList.options[t].value=='') continue;
var tiddler=store.getTiddler(theList.options[t].value); if (!tiddler) continue;
theList.options[t].selected=(tiddler.modified>lastmod);
count += (tiddler.modified>lastmod)?1:0;
}
this.$('exportStart').disabled=(count==0);
this.$('exportDelete').disabled=(count==0);
this.displayStatus(count,total);
if (count==0) alert('There are no unsaved changes');
break;
case 'exportSelectAll':
for (var t = 0; t < theList.options.length; t++) {
if (theList.options[t].value=='') continue;
theList.options[t].selected=true;
count += 1;
}
this.$('exportStart').disabled=(count==0);
this.$('exportDelete').disabled=(count==0);
this.displayStatus(count,count);
break;
case 'exportSelectOpened':
for (var t=0; t<theList.options.length; t++) theList.options[t].selected=false;
var tiddlerDisplay=this.$('tiddlerDisplay');
for (var t=0; t<tiddlerDisplay.childNodes.length;t++) {
var tiddler=tiddlerDisplay.childNodes[t].id.substr(7);
for (var i=0; i<theList.options.length; i++) {
if (theList.options[i].value!=tiddler) continue;
theList.options[i].selected=true; count++; break;
}
}
this.$('exportStart').disabled=(count==0);
this.$('exportDelete').disabled=(count==0);
this.displayStatus(count,total);
if (count==0) alert('There are no tiddlers currently opened');
break;
case 'exportSelectRelated':
// recursively build list of related tiddlers
function getRelatedTiddlers(tid,tids) {
var t=store.getTiddler(tid); if (!t || tids.contains(tid)) return tids;
tids.push(t.title);
if (!t.linksUpdated) t.changed();
for (var i=0; i<t.links.length; i++)
if (t.links[i]!=tid) tids=getRelatedTiddlers(t.links[i],tids);
return tids;
}
// for all currently selected tiddlers, gather up the related tiddlers (including self) and select them as well
var tids=[];
for (var i=0; i<theList.options.length; i++)
if (theList.options[i].selected) tids=getRelatedTiddlers(theList.options[i].value,tids);
// select related tiddlers (includes original selected tiddlers)
for (var i=0; i<theList.options.length; i++)
theList.options[i].selected=tids.contains(theList.options[i].value);
this.displayStatus(tids.length,total);
break;
case 'exportListSmaller': // decrease current listbox size
var min=5;
theList.size-=(theList.size>min)?1:0;
break;
case 'exportListLarger': // increase current listbox size
var max=(theList.options.length>25)?theList.options.length:25;
theList.size+=(theList.size<max)?1:0;
break;
case 'exportClose':
this.$('exportPanel').style.display='none';
break;
}
return false;
},
displayStatus: function(count,total) {
var txt=this.statusmsg.format([total,total!=1?'s':'',!count?'none':count==total?'all':count]);
clearMessage(); displayMessage(txt);
return txt;
},
refreshList: function(selectedIndex) {
var theList = this.$('exportList'); if (!theList) return;
// get the sort order
var sort;
if (!selectedIndex) selectedIndex=0;
if (selectedIndex==0) sort='modified';
if (selectedIndex==1) sort='title';
if (selectedIndex==2) sort='modified';
if (selectedIndex==3) sort='modifier';
if (selectedIndex==4) sort='tags';
// unselect headings and count number of tiddlers actually selected
var count=0;
for (var t=5; t < theList.options.length; t++) {
if (!theList.options[t].selected) continue;
if (theList.options[t].value!='')
count++;
else { // if heading is selected, deselect it, and then select and count all in section
theList.options[t].selected=false;
for ( t++; t<theList.options.length && theList.options[t].value!=''; t++) {
theList.options[t].selected=true;
count++;
}
}
}
// disable 'export' and 'delete' buttons if no tiddlers selected
this.$('exportStart').disabled=(count==0);
this.$('exportDelete').disabled=(count==0);
// show selection count
var tiddlers = store.getTiddlers('title');
if (theList.options.length) this.displayStatus(count,tiddlers.length);
// if a [command] item, reload list... otherwise, no further refresh needed
if (selectedIndex>4) return;
// clear current list contents
while (theList.length > 0) { theList.options[0] = null; }
// add heading and control items to list
var i=0;
var indent=String.fromCharCode(160)+String.fromCharCode(160);
theList.options[i++]=
new Option(tiddlers.length+' tiddlers in document', '',false,false);
theList.options[i++]=
new Option(((sort=='title' )?'>':indent)+' [by title]', '',false,false);
theList.options[i++]=
new Option(((sort=='modified')?'>':indent)+' [by date]', '',false,false);
theList.options[i++]=
new Option(((sort=='modifier')?'>':indent)+' [by author]', '',false,false);
theList.options[i++]=
new Option(((sort=='tags' )?'>':indent)+' [by tags]', '',false,false);
// output the tiddler list
switch(sort) {
case 'title':
for(var t = 0; t < tiddlers.length; t++)
theList.options[i++] = new Option(tiddlers[t].title,tiddlers[t].title,false,false);
break;
case 'modifier':
case 'modified':
var tiddlers = store.getTiddlers(sort);
// sort descending for newest date first
tiddlers.sort(function (a,b) {if(a[sort] == b[sort]) return(0); else return (a[sort] > b[sort]) ? -1 : +1; });
var lastSection = '';
for(var t = 0; t < tiddlers.length; t++) {
var tiddler = tiddlers[t];
var theSection = '';
if (sort=='modified') theSection=tiddler.modified.toLocaleDateString();
if (sort=='modifier') theSection=tiddler.modifier;
if (theSection != lastSection) {
theList.options[i++] = new Option(theSection,'',false,false);
lastSection = theSection;
}
theList.options[i++] = new Option(indent+indent+tiddler.title,tiddler.title,false,false);
}
break;
case 'tags':
var theTitles = {}; // all tiddler titles, hash indexed by tag value
var theTags = new Array();
for(var t=0; t<tiddlers.length; t++) {
var title=tiddlers[t].title;
var tags=tiddlers[t].tags;
if (!tags || !tags.length) {
if (theTitles['untagged']==undefined) { theTags.push('untagged'); theTitles['untagged']=new Array(); }
theTitles['untagged'].push(title);
}
else for(var s=0; s<tags.length; s++) {
if (theTitles[tags[s]]==undefined) { theTags.push(tags[s]); theTitles[tags[s]]=new Array(); }
theTitles[tags[s]].push(title);
}
}
theTags.sort();
for(var tagindex=0; tagindex<theTags.length; tagindex++) {
var theTag=theTags[tagindex];
theList.options[i++]=new Option(theTag,'',false,false);
for(var t=0; t<theTitles[theTag].length; t++)
theList.options[i++]=new Option(indent+indent+theTitles[theTag][t],theTitles[theTag][t],false,false);
}
break;
}
theList.selectedIndex=selectedIndex; // select current control item
this.$('exportStart').disabled=true;
this.$('exportDelete').disabled=true;
this.displayStatus(0,tiddlers.length);
},
askForFilename: function(here) {
var msg=here.title; // use tooltip as dialog box message
var path=getLocalPath(document.location.href);
var slashpos=path.lastIndexOf('/'); if (slashpos==-1) slashpos=path.lastIndexOf('\\');
if (slashpos!=-1) path = path.substr(0,slashpos+1); // remove filename from path, leave the trailing slash
var filetype=this.$('exportFormat').value.toLowerCase();
var defext='html';
if (filetype==this.type_TX) defext='txt';
if (filetype==this.type_CS) defext='csv';
if (filetype==this.type_NF) defext='xml';
var file=this.newdefault.replace(/html$/,defext);
var result='';
if(window.Components) { // moz
try {
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
var nsIFilePicker = window.Components.interfaces.nsIFilePicker;
var picker = Components.classes['@mozilla.org/filepicker;1'].createInstance(nsIFilePicker);
picker.init(window, msg, nsIFilePicker.modeSave);
var thispath = Components.classes['@mozilla.org/file/local;1'].createInstance(Components.interfaces.nsILocalFile);
thispath.initWithPath(path);
picker.displayDirectory=thispath;
picker.defaultExtension=defext;
picker.defaultString=file;
picker.appendFilters(nsIFilePicker.filterAll|nsIFilePicker.filterText|nsIFilePicker.filterHTML);
if (picker.show()!=nsIFilePicker.returnCancel) var result=picker.file.persistentDescriptor;
}
catch(e) { alert('error during local file access: '+e.toString()) }
}
else { // IE
try { // XPSP2 IE only
var s = new ActiveXObject('UserAccounts.CommonDialog');
s.Filter='All files|*.*|Text files|*.txt|HTML files|*.htm;*.html|XML files|*.xml|';
s.FilterIndex=defext=='txt'?2:'html'?3:'xml'?4:1;
s.InitialDir=path;
s.FileName=file;
if (s.showOpen()) var result=s.FileName;
}
catch(e) { // fallback
var result=prompt(msg,path+file);
}
}
return result;
},
initFilter: function() {
this.$('exportFilterStart').checked=false; this.$('exportStartDate').value='';
this.$('exportFilterEnd').checked=false; this.$('exportEndDate').value='';
this.$('exportFilterTags').checked=false; this.$('exportTags').value='';
this.$('exportFilterText').checked=false; this.$('exportText').value='';
this.showFilterFields();
},
showFilterFields: function(which) {
var show=this.$('exportFilterStart').checked;
this.$('exportFilterStartBy').style.display=show?'block':'none';
this.$('exportStartDate').style.display=show?'block':'none';
var val=this.$('exportFilterStartBy').value;
this.$('exportStartDate').value
=this.getFilterDate(val,'exportStartDate').formatString(this.datetimefmt);
if (which && (which.id=='exportFilterStartBy') && (val=='other'))
this.$('exportStartDate').focus();
var show=this.$('exportFilterEnd').checked;
this.$('exportFilterEndBy').style.display=show?'block':'none';
this.$('exportEndDate').style.display=show?'block':'none';
var val=this.$('exportFilterEndBy').value;
this.$('exportEndDate').value
=this.getFilterDate(val,'exportEndDate').formatString(this.datetimefmt);
if (which && (which.id=='exportFilterEndBy') && (val=='other'))
this.$('exportEndDate').focus();
var show=this.$('exportFilterTags').checked;
this.$('exportTags').style.display=show?'block':'none';
var show=this.$('exportFilterText').checked;
this.$('exportText').style.display=show?'block':'none';
},
getFilterDate: function(val,id) {
var result=0;
switch (val) {
case 'file':
result=new Date(document.lastModified);
break;
case 'other':
result=new Date(this.$(id).value);
break;
default: // today=0, yesterday=1, one week=7, two weeks=14, a month=31
var now=new Date(); var tz=now.getTimezoneOffset()*60000; now-=tz;
var oneday=86400000;
if (id=='exportStartDate')
result=new Date((Math.floor(now/oneday)-val)*oneday+tz);
else
result=new Date((Math.floor(now/oneday)-val+1)*oneday+tz-1);
break;
}
return result;
},
filterExportList: function() {
var theList = this.$('exportList'); if (!theList) return -1;
var filterStart=this.$('exportFilterStart').checked;
var val=this.$('exportFilterStartBy').value;
var startDate=config.macros.exportTiddlers.getFilterDate(val,'exportStartDate');
var filterEnd=this.$('exportFilterEnd').checked;
var val=this.$('exportFilterEndBy').value;
var endDate=config.macros.exportTiddlers.getFilterDate(val,'exportEndDate');
var filterTags=this.$('exportFilterTags').checked;
var tags=this.$('exportTags').value;
var filterText=this.$('exportFilterText').checked;
var text=this.$('exportText').value;
if (!(filterStart||filterEnd||filterTags||filterText)) {
alert('Please set the selection filter');
this.$('exportFilterPanel').style.display='block';
return -1;
}
if (filterStart&&filterEnd&&(startDate>endDate)) {
var msg='starting date/time:\n'
msg+=startDate.toLocaleString()+'\n';
msg+='is later than ending date/time:\n'
msg+=endDate.toLocaleString()
alert(msg);
return -1;
}
// if filter by tags, get list of matching tiddlers
// use getMatchingTiddlers() (if MatchTagsPlugin is installed) for full boolean expressions
// otherwise use getTaggedTiddlers() for simple tag matching
if (filterTags) {
var fn=store.getMatchingTiddlers||store.getTaggedTiddlers;
var t=fn.apply(store,[tags]);
var tagged=[];
for (var i=0; i<t.length; i++) tagged.push(t[i].title);
}
// scan list and select tiddlers that match all applicable criteria
var total=0;
var count=0;
for (var i=0; i<theList.options.length; i++) {
// get item, skip non-tiddler list items (section headings)
var opt=theList.options[i]; if (opt.value=='') continue;
// get tiddler, skip missing tiddlers (this should NOT happen)
var tiddler=store.getTiddler(opt.value); if (!tiddler) continue;
var sel=true;
if ( (filterStart && tiddler.modified<startDate)
|| (filterEnd && tiddler.modified>endDate)
|| (filterTags && !tagged.contains(tiddler.title))
|| (filterText && (tiddler.text.indexOf(text)==-1) && (tiddler.title.indexOf(text)==-1)))
sel=false;
opt.selected=sel;
count+=sel?1:0;
total++;
}
return count;
},
deleteTiddlers: function() {
var list=this.$('exportList'); if (!list) return;
var tids=[];
for (i=0;i<list.length;i++)
if (list.options[i].selected && list.options[i].value.length)
tids.push(list.options[i].value);
if (!confirm('Are you sure you want to delete these tiddlers:\n\n'+tids.join(', '))) return;
store.suspendNotifications();
for (t=0;t<tids.length;t++) {
var tid=store.getTiddler(tids[t]); if (!tid) continue;
var msg="'"+tid.title+"' is tagged with 'systemConfig'.\n\n";
msg+='Removing this tiddler may cause unexpected results. Are you sure?'
if (tid.tags.contains('systemConfig') && !confirm(msg)) continue;
store.removeTiddler(tid.title);
story.closeTiddler(tid.title);
}
store.resumeNotifications();
alert(tids.length+' tiddlers deleted');
this.refreshList(0); // reload listbox
store.notifyAll(); // update page display
},
go: function() {
if (window.location.protocol!='file:') // make sure we are local
{ displayMessage(config.messages.notFileUrlError); return; }
// get selected tidders, target filename, target type, and notes
var list=this.$('exportList'); if (!list) return;
var tids=[]; for (var i=0; i<list.options.length; i++) {
var opt=list.options[i]; if (!opt.selected||!opt.value.length) continue;
var tid=store.getTiddler(opt.value); if (!tid) continue;
tids.push(tid);
}
if (!tids.length) return; // no tiddlers selected
var target=this.$('exportFilename').value.trim();
if (!target.length) {
displayMessage('A local target path/filename is required',target);
return;
}
var merge=this.$('exportMerge').checked;
var filetype=this.$('exportFormat').value.toLowerCase();
var notes=this.$('exportNotes').value.replace(/\n/g,'<br>');
var total={val:0};
var out=this.assembleFile(target,filetype,tids,notes,total,merge);
if (!total.val) return; // cancelled file overwrite
var link='file:///'+target.replace(/\\/g,'/');
var samefile=link==decodeURIComponent(window.location.href);
var p=getLocalPath(document.location.href);
if (samefile) {
if (config.options.chkSaveBackups) { var t=loadOriginal(p);if(t)saveBackup(p,t); }
if (config.options.chkGenerateAnRssFeed && saveRss instanceof Function) saveRss(p);
}
var ok=saveFile(target,out);
displayMessage((ok?this.okmsg:this.failmsg).format([total.val,total.val!=1?'s':'',target]),link);
},
plainTextHeader:
'Source:\n\t%0\n'
+'Title:\n\t%1\n'
+'Subtitle:\n\t%2\n'
+'Created:\n\t%3 by %4\n'
+'Application:\n\tTiddlyWiki %5 / %6 %7\n\n',
plainTextTiddler:
'- - - - - - - - - - - - - - -\n'
+'| title: %0\n'
+'| created: %1\n'
+'| modified: %2\n'
+'| edited by: %3\n'
+'| tags: %4\n'
+'- - - - - - - - - - - - - - -\n'
+'%5\n',
plainTextFooter:
'',
newsFeedHeader:
'<'+'?xml version="1.0"?'+'>\n'
+'<rss version="2.0">\n'
+'<channel>\n'
+'<title>%1</title>\n'
+'<link>%0</link>\n'
+'<description>%2</description>\n'
+'<language>en-us</language>\n'
+'<copyright>Copyright '+(new Date().getFullYear())+' %4</copyright>\n'
+'<pubDate>%3</pubDate>\n'
+'<lastBuildDate>%3</lastBuildDate>\n'
+'<docs>http://blogs.law.harvard.edu/tech/rss</docs>\n'
+'<generator>TiddlyWiki %5 / %6 %7</generator>\n',
newsFeedTiddler:
'\n%0\n',
newsFeedFooter:
'</channel></rss>',
pureStoreHeader:
'<html><body>'
+'<style type="text/css">'
+' #storeArea {display:block;margin:1em;}'
+' #storeArea div {padding:0.5em;margin:1em;border:2px solid black;height:10em;overflow:auto;}'
+' #pureStoreHeading {width:100%;text-align:left;background-color:#eeeeee;padding:1em;}'
+'</style>'
+'<div id="pureStoreHeading">'
+' TiddlyWiki "PureStore" export file<br>'
+' Source'+': <b>%0</b><br>'
+' Title: <b>%1</b><br>'
+' Subtitle: <b>%2</b><br>'
+' Created: <b>%3</b> by <b>%4</b><br>'
+' TiddlyWiki %5 / %6 %7<br>'
+' Notes:<hr><pre>%8</pre>'
+'</div>'
+'<div id="storeArea">',
pureStoreTiddler:
'%0\n%1',
pureStoreFooter:
'</div><!--POST-BODY-START-->\n<!--POST-BODY-END--></body></html>',
assembleFile: function(target,filetype,tids,notes,total,merge) {
var revised='';
var now = new Date().toLocaleString();
var src=convertUnicodeToUTF8(document.location.href);
var title = convertUnicodeToUTF8(wikifyPlain('SiteTitle').htmlEncode());
var subtitle = convertUnicodeToUTF8(wikifyPlain('SiteSubtitle').htmlEncode());
var user = convertUnicodeToUTF8(config.options.txtUserName.htmlEncode());
var twver = version.major+'.'+version.minor+'.'+version.revision;
var v=version.extensions.ExportTiddlersPlugin; var pver = v.major+'.'+v.minor+'.'+v.revision;
var headerargs=[src,title,subtitle,now,user,twver,'ExportTiddlersPlugin',pver,notes];
switch (filetype) {
case this.type_TX: // plain text
var header=this.plainTextHeader.format(headerargs);
var footer=this.plainTextFooter;
break;
case this.type_CS: // comma-separated
var fields={};
for (var i=0; i<tids.length; i++) for (var f in tids[i].fields) fields[f]=f;
var names=['title','created','modified','modifier','tags','text'];
for (var f in fields) names.push(f);
var header=names.join(',')+'\n';
var footer='';
break;
case this.type_NF: // news feed (XML)
headerargs[0]=store.getTiddlerText('SiteUrl','');
var header=this.newsFeedHeader.format(headerargs);
var footer=this.newsFeedFooter;
break;
case this.type_PS: // PureStore (no code)
var header=this.pureStoreHeader.format(headerargs);
var footer=this.pureStoreFooter;
break;
case this.type_TW: // full TiddlyWiki
default:
var currPath=getLocalPath(window.location.href);
var original=loadFile(currPath);
if (!original) { displayMessage(config.messages.cantSaveError); return; }
var posDiv = locateStoreArea(original);
if (!posDiv) { displayMessage(config.messages.invalidFileError.format([currPath])); return; }
var header = original.substr(0,posDiv[0]+startSaveArea.length)+'\n';
var footer = '\n'+original.substr(posDiv[1]);
break;
}
var out=this.getData(target,filetype,tids,fields,merge);
var revised = header+convertUnicodeToUTF8(out.join('\n'))+footer;
// if full TW, insert page title and language attr, and reset all MARKUP blocks...
if (filetype==this.type_TW) {
var newSiteTitle=convertUnicodeToUTF8(getPageTitle()).htmlEncode();
revised=revised.replaceChunk('<title'+'>','</title'+'>',' ' + newSiteTitle + ' ');
revised=updateLanguageAttribute(revised);
var titles=[]; for (var i=0; i<tids.length; i++) titles.push(tids[i].title);
revised=updateMarkupBlock(revised,'PRE-HEAD',
titles.contains('MarkupPreHead')? 'MarkupPreHead' :null);
revised=updateMarkupBlock(revised,'POST-HEAD',
titles.contains('MarkupPostHead')?'MarkupPostHead':null);
revised=updateMarkupBlock(revised,'PRE-BODY',
titles.contains('MarkupPreBody')? 'MarkupPreBody' :null);
revised=updateMarkupBlock(revised,'POST-SCRIPT',
titles.contains('MarkupPostBody')?'MarkupPostBody':null);
}
total.val=out.length;
return revised;
},
getData: function(target,filetype,tids,fields,merge) {
// output selected tiddlers and gather list of titles (for use with merge)
var out=[]; var titles=[];
var url=store.getTiddlerText('SiteUrl','');
for (var i=0; i<tids.length; i++) {
out.push(this.formatItem(store,filetype,tids[i],url,fields));
titles.push(tids[i].title);
}
// if TW or PureStore format, ask to merge with existing tiddlers (if any)
if (filetype==this.type_TW || filetype==this.type_PS) {
var txt=loadFile(target);
if (txt && txt.length) {
var remoteStore=new TiddlyWiki();
if (version.major+version.minor*.1+version.revision*.01<2.52) txt=convertUTF8ToUnicode(txt);
if (remoteStore.importTiddlyWiki(txt)) {
var existing=remoteStore.getTiddlers('title');
var msg=this.overwriteprompt.format([target,existing.length,existing.length!=1?'s':'']);
if (merge) {
var added=titles.length; var updated=0; var kept=0;
for (var i=0; i<existing.length; i++)
if (titles.contains(existing[i].title)) {
added--; updated++;
} else {
out.push(this.formatItem(remoteStore,filetype,existing[i],url));
kept++;
}
displayMessage(this.mergestatus.format(
[added,added!=1?'s':'',updated,updated!=1?'s':'',kept,kept!=1?'s':'',]));
}
else if (!confirm(msg)) out=[]; // empty the list = don't write file
}
}
}
return out;
},
formatItem: function(s,f,t,u,fields) {
if (f==this.type_TW)
var r=s.getSaver().externalizeTiddler(s,t);
if (f==this.type_PS)
var r=this.pureStoreTiddler.format([t.title,s.getSaver().externalizeTiddler(s,t)]);
if (f==this.type_NF)
var r=this.newsFeedTiddler.format([t.saveToRss(u)]);
if (f==this.type_TX)
var r=this.plainTextTiddler.format([t.title, t.created.toLocaleString(), t.modified.toLocaleString(),
t.modifier, String.encodeTiddlyLinkList(t.tags), t.text]);
if (f==this.type_CS) {
function toCSV(t) { return '"'+t.replace(/"/g,'""')+'"'; } // always encode CSV
var out=[ toCSV(t.title), toCSV(t.created.toLocaleString()), toCSV(t.modified.toLocaleString()),
toCSV(t.modifier), toCSV(String.encodeTiddlyLinkList(t.tags)), toCSV(t.text) ];
for (var f in fields) out.push(toCSV(t.fields[f]||''));
var r=out.join(',');
}
return r||"";
}
}
//}}}
/***
!!!Control panel CSS
//{{{
!css
#exportPanel {
display: none; position:absolute; z-index:12; width:90%; right:105%; top:6em;
background-color: #eee; color:#000; font-size: 8pt; line-height:110%;
border:1px solid black; border-bottom-width: 3px; border-right-width: 3px;
padding: 0.5em; margin:0em; -moz-border-radius:1em;-webkit-border-radius:1em;
}
#exportPanel a, #exportPanel td a { color:#009; display:inline; margin:0px; padding:1px; }
#exportPanel table {
width:100%; border:0px; padding:0px; margin:0px;
font-size:8pt; line-height:110%; background:transparent;
}
#exportPanel tr { border:0px;padding:0px;margin:0px; background:transparent; }
#exportPanel td { color:#000; border:0px;padding:0px;margin:0px; background:transparent; }
#exportPanel select { width:98%;margin:0px;font-size:8pt;line-height:110%;}
#exportPanel input { width:98%;padding:0px;margin:0px;font-size:8pt;line-height:110%; }
#exportPanel textarea { width:98%;padding:0px;margin:0px;overflow:auto;font-size:8pt; }
#exportPanel .box {
border:1px solid black; padding:3px; margin-bottom:5px;
background:#f8f8f8; -moz-border-radius:5px;-webkit-border-radius:5px; }
#exportPanel .topline { border-top:2px solid black; padding-top:3px; margin-bottom:5px; }
#exportPanel .rad { width:auto;border:0 }
#exportPanel .chk { width:auto;border:0 }
#exportPanel .btn { width:auto; }
#exportPanel .btn1 { width:98%; }
#exportPanel .btn2 { width:48%; }
#exportPanel .btn3 { width:32%; }
#exportPanel .btn4 { width:24%; }
#exportPanel .btn5 { width:19%; }
!end
//}}}
!!!Control panel HTML
//{{{
!html
<!-- target path/file -->
<div>
<div style="float:right;padding-right:.5em">
<input type="checkbox" style="width:auto" id="exportMerge" CHECKED
title="combine selected tiddlers with existing tiddlers (if any) in export file"> merge
</div>
export to:<br>
<input type="text" id="exportFilename" size=40 style="width:93%"><input
type="button" id="exportBrowse" value="..." title="select or enter a local folder/file..." style="width:5%"
onclick="var fn=config.macros.exportTiddlers.askForFilename(this); if (fn.length) this.previousSibling.value=fn; ">
</div>
<!-- output format -->
<div>
format:
<select id="exportFormat" size=1>
<option value="TW">TiddlyWiki HTML document (includes core code)</option>
<option value="PS">TiddlyWiki "PureStore" HTML file (tiddler data only)</option>
<option value="TX">TiddlyWiki plain text TXT file (tiddler source listing)</option>
<option value="CS">Comma-Separated Value (CSV) data file</option>
<option value="NF">RSS NewsFeed XML file</option>
</select>
</div>
<!-- notes -->
<div>
notes:<br>
<textarea id="exportNotes" rows=3 cols=40 style="height:10em;margin-bottom:5px;" onfocus="this.select()"></textarea>
</div>
<!-- list of tiddlers -->
<table><tr align="left"><td>
select:
<a href="JavaScript:;" id="exportSelectAll"
onclick="return config.macros.exportTiddlers.process(this)" title="select all tiddlers">
all </a>
<a href="JavaScript:;" id="exportSelectChanges"
onclick="return config.macros.exportTiddlers.process(this)" title="select tiddlers changed since last save">
changes </a>
<a href="JavaScript:;" id="exportSelectOpened"
onclick="return config.macros.exportTiddlers.process(this)" title="select tiddlers currently being displayed">
opened </a>
<a href="JavaScript:;" id="exportSelectRelated"
onclick="return config.macros.exportTiddlers.process(this)" title="select tiddlers related to the currently selected tiddlers">
related </a>
<a href="JavaScript:;" id="exportToggleFilter"
onclick="return config.macros.exportTiddlers.process(this)" title="show/hide selection filter">
filter </a>
</td><td align="right">
<a href="JavaScript:;" id="exportListSmaller"
onclick="return config.macros.exportTiddlers.process(this)" title="reduce list size">
– </a>
<a href="JavaScript:;" id="exportListLarger"
onclick="return config.macros.exportTiddlers.process(this)" title="increase list size">
+ </a>
</td></tr></table>
<select id="exportList" multiple size="10" style="height:50em; margin-bottom:5px;"
onchange="config.macros.exportTiddlers.refreshList(this.selectedIndex)">
</select><br>
<!-- selection filter -->
<div id="exportFilterPanel" style="display:none">
<table><tr align="left"><td>
selection filter
</td><td align="right">
<a href="JavaScript:;" id="exportHideFilter"
onclick="return config.macros.exportTiddlers.process(this)" title="hide selection filter">hide</a>
</td></tr></table>
<div class="box">
<input type="checkbox" class="chk" id="exportFilterStart" value="1"
onclick="config.macros.exportTiddlers.showFilterFields(this)"> starting date/time<br>
<table cellpadding="0" cellspacing="0"><tr valign="center"><td width="50%">
<select size=1 id="exportFilterStartBy"
onchange="config.macros.exportTiddlers.showFilterFields(this);">
<option value="0">today</option>
<option value="1">yesterday</option>
<option value="7">a week ago</option>
<option value="30">a month ago</option>
<option value="file">file date</option>
<option value="other">other (mm/dd/yyyy hh:mm)</option>
</select>
</td><td width="50%">
<input type="text" id="exportStartDate" onfocus="this.select()"
onchange="config.macros.exportTiddlers.$('exportFilterStartBy').value='other';">
</td></tr></table>
<input type="checkbox" class="chk" id="exportFilterEnd" value="1"
onclick="config.macros.exportTiddlers.showFilterFields(this)"> ending date/time<br>
<table cellpadding="0" cellspacing="0"><tr valign="center"><td width="50%">
<select size=1 id="exportFilterEndBy"
onchange="config.macros.exportTiddlers.showFilterFields(this);">
<option value="0">today</option>
<option value="1">yesterday</option>
<option value="7">a week ago</option>
<option value="30">a month ago</option>
<option value="file">file date</option>
<option value="other">other (mm/dd/yyyy hh:mm)</option>
</select>
</td><td width="50%">
<input type="text" id="exportEndDate" onfocus="this.select()"
onchange="config.macros.exportTiddlers.$('exportFilterEndBy').value='other';">
</td></tr></table>
<input type="checkbox" class="chk" id=exportFilterTags value="1"
onclick="config.macros.exportTiddlers.showFilterFields(this)"> match tags<br>
<input type="text" id="exportTags" onfocus="this.select()">
<input type="checkbox" class="chk" id=exportFilterText value="1"
onclick="config.macros.exportTiddlers.showFilterFields(this)"> match titles/tiddler text<br>
<input type="text" id="exportText" onfocus="this.select()">
</div> <!--box-->
</div> <!--panel-->
<!-- action buttons -->
<div style="text-align:center">
<input type=button class="btn4" onclick="config.macros.exportTiddlers.process(this)"
id="exportFilter" value="apply filter">
<input type=button class="btn4" onclick="config.macros.exportTiddlers.process(this)"
id="exportStart" value="export tiddlers">
<input type=button class="btn4" onclick="config.macros.exportTiddlers.process(this)"
id="exportDelete" value="delete tiddlers">
<input type=button class="btn4" onclick="config.macros.exportTiddlers.process(this)"
id="exportClose" value="close">
</div><!--center-->
!end
//}}}
***/
<<myComment>>
----
~~:::::__Fri Jun 25 2010 20:56:03 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ My eyes hurt. Made the box bigger. Maybe too big...
/***
|Name|ExternalTiddlersPlugin|
|Source|http://www.TiddlyTools.com/#ExternalTiddlersPlugin|
|Documentation|http://www.TiddlyTools.com/#ExternalTiddlersPluginInfo|
|Version|1.3.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Requires|TemporaryTiddlersPlugin (optional, recommended)|
|Description|retrieve and wikify content from external files or remote URLs|
This plugin extends the {{{<<tiddler>>}}} macro syntax so you can retrieve and wikify content directly from external files or remote URLs. You can also define alternative "fallback" sources to provide basic "import on demand" handling by automatically creating/importing tiddler content from external sources when the specified ~TiddlerName does not already exist in your document.
!!!!!Documentation
>see [[ExternalTiddlersPluginInfo]]
!!!!!Configuration
<<<
<<option chkExternalTiddlersImport>> automatically create/import tiddlers when using external fallback references
{{{usage: <<option chkExternalTiddlersImport>>}}}
<<option chkExternalTiddlersQuiet>> don't display messages when adding tiddlers ("quiet mode")
{{{usage: <<option chkExternalTiddlersQuiet>>}}}
<<option chkExternalTiddlersTemporary>> tag retrieved tiddlers as 'temporary'(requires [[TemporaryTiddlersPlugin]])
{{{usage: <<option chkExternalTiddlersTemporary>>}}}
tag retrieved tiddlers with: <<option txtExternalTiddlersTags>>
{{{usage: <<option txtExternalTiddlersTags>>}}}
__password-protected server settings //(optional, if needed)//:__
>username: <<option txtRemoteUsername>> password: <<option txtRemotePassword>>
>{{{usage: <<option txtRemoteUsername>> <<option txtRemotePassword>>}}}
>''note: these settings are also used by [[LoadTiddlersPlugin]] and [[ImportTiddlersPlugin]]''
<<<
!!!!!Revisions
<<<
2008.10.27 [1.3.1] in insertTiddler(), fixed Safari bug by replacing static Array.concat(...) with new Array().concat(...)
|please see [[ExternalTiddlersPluginInfo]] for additional revision details|
2007.11.25 [1.0.0] initial release - moved from CoreTweaks
<<<
!!!!!Code
***/
//{{{
version.extensions.ExternalTiddlersPlugin= {major: 1, minor: 3, revision: 1, date: new Date(2008,10,27)};
// optional automatic import/create for missing tiddlers
if (config.options.chkExternalTiddlersImport==undefined) config.options.chkExternalTiddlersImport=true;
if (config.options.chkExternalTiddlersTemporary==undefined) config.options.chkExternalTiddlersTemporary=true;
if (config.options.chkExternalTiddlersQuiet==undefined) config.options.chkExternalTiddlersQuiet=false;
if (config.options.txtExternalTiddlersTags==undefined) config.options.txtExternalTiddlersTags="external";
if (config.options.txtRemoteUsername==undefined) config.options.txtRemoteUsername="";
if (config.options.txtRemotePassword==undefined) config.options.txtRemotePassword="";
config.macros.tiddler.externalTiddlers_handler = config.macros.tiddler.handler;
config.macros.tiddler.handler = function(place,macroName,params,wikifier,paramString,tiddler)
{
params = paramString.parseParams("name",null,true,false,true);
var names = params[0]["name"];
var list = names[0];
var items = list.split("|");
var className = names[1] ? names[1] : null;
var args = params[0]["with"];
// UTILITY FUNCTIONS
function extract(text,tids) { // get tiddler source content from plain text or TW doc
if (!text || !tids || !tids.length) return text; // no text or no tiddler list... return text as-is
var remoteStore=new TiddlyWiki();
if (!remoteStore.importTiddlyWiki(text)) return text; // not a TW document... return text as-is
var out=[]; for (var t=0;t<tids.length;t++)
{ var txt=remoteStore.getTiddlerText(tids[t]); if (txt) out.push(txt); }
return out.join("\n");
}
function substitute(text,args) { // replace "substitution markers" ($1-$9) with macro param values (if any)
if (!text || !args || !args.length) return text;
var n=args.length; if (n>9) n=9;
for(var i=0; i<n; i++) { var re=new RegExp("\\$" + (i + 1),"mg"); text=text.replace(re,args[i]); }
return text;
}
function addTiddler(src,text,tids) { // extract tiddler(s) from text and create local copy
if (!config.options.chkExternalTiddlersImport) return; // not enabled... do nothing
if (!text || !tids || !tids.length) return; // no text or no tiddler list... do nothing
var remoteStore=new TiddlyWiki();
if (!remoteStore.importTiddlyWiki(text)) // not a TW document... create a single tiddler from text
makeTiddler(src,text,tids[0]);
else // TW document with "permaview-like" suffix... copy tiddler(s) from remote store
for (var t=0;t<tids.length;t++)
insertTiddler(src,remoteStore.getTiddler(tids[t]));
return;
}
function makeTiddler(src,text,title) { // create a new tiddler object from text
var who=config.options.txtUserName; var when=new Date();
var msg="/%\n\nThis tiddler was automatically created using ExternalTiddlersPlugin\n";
msg+="by %0 on %1\nsource: %2\n\n%/";
var tags=config.options.txtExternalTiddlersTags.readBracketedList();
if (config.options.chkExternalTiddlersTemporary) tags.pushUnique(config.options.txtTemporaryTag);
store.saveTiddler(null,title,msg.format([who,when,src])+text,who,when,tags,{});
if (!config.options.chkExternalTiddlersQuiet) displayMessage("Created new tiddler '"+title+"' from text file "+src);
}
function insertTiddler(src,t) { // import a single tiddler object into the current document store
if (!t) return;
var who=config.options.txtUserName; var when=new Date();
var msg="/%\n\nThis tiddler was automatically imported using ExternalTiddlersPlugin\n";
msg+="by %0 on %1\nsource: %2\n\n%/";
var newtags=new Array().concat(t.tags,config.options.txtExternalTiddlersTags.readBracketedList());
if (config.options.chkExternalTiddlersTemporary) newtags.push(config.options.txtTemporaryTag);
store.saveTiddler(null,t.title,msg.format([who,when,src])+t.text,t.modifier,t.modified,newtags,t.fields);
if (!config.options.chkExternalTiddlersQuiet) displayMessage("Imported tiddler '"+t.title+"' from "+src);
}
function getGUID() // create a Globally Unique ID (for async reference to DOM elements)
{ return new Date().getTime()+Math.random().toString(); }
// loop through "|"-separated list of alternative tiddler/file/URL references until successful
var fallback="";
for (var i=0; i<items.length; i++) { var src=items[i];
// if tiddler (or shadow) exists, replace reference list with current source name and apply core handler
if (store.getTiddlerText(src)) {
arguments[2][0]=src; // params[] array
var p=arguments[4].split(list); arguments[4]=p[0]+src+p[1]; // paramString
this.externalTiddlers_handler.apply(this,arguments);
break; // stop processing alternatives
}
// tiddler doesn't exist, and not an external file/URL reference... skip it
if (!config.formatterHelpers.isExternalLink(src)) {
if (!fallback.length) fallback=src; // title to use when importing external tiddler
continue;
}
// separate 'permaview' list of tiddlers (if any) from file/URL (i.e., '#name name name..." suffix)
var p=src.split("#"); src=p[0]; var tids=p[1]?p[1].readBracketedList(false):[];
// if reference is to a remotely hosted document or the current document is remotely hosted...
if (src.substr(0,4)=="http" || document.location.protocol.substr(0,4)=="http") {
if (src.substr(0,4)!="http") // fixup URL for relative remote references
{ var h=document.location.href; src=h.substr(0,h.lastIndexOf("/")+1)+src; }
var wrapper = createTiddlyElement(place,"span",getGUID(),className); // create placeholder for async rendering
var callback=function(success,params,text,src,xhr) { // ASYNC CALLBACK
if (!success) { displayMessage(xhr.status); return; } // couldn't read remote file... report the error
if (params.fallback.length)
addTiddler(params.url,text,params.tids.length?params.tids:[params.fallback]); // import tiddler
var wrapper=document.getElementById(params.id); if (!wrapper) return;
wikify(substitute(extract(text,params.tids),params.args),wrapper); // ASYNC RENDER
};
var callbackparams={ url:src, id:wrapper.id, args:args, tids:tids, fallback:fallback } // ASYNC PARAMS
var name=config.options.txtRemoteUsername; // optional value
var pass=config.options.txtRemotePassword; // optional value
var x=doHttp("GET",src,null,null,name,pass,callback,callbackparams,null)
if (typeof(x)=="string") // couldn't start XMLHttpRequest... report error
{ displayMessage("error: cannot access "+src); displayMessage(x); }
break; // can't tell if async read will succeed.... stop processing alternatives anyway.
}
else { // read file from local filesystem
var text=loadFile(getLocalPath(src));
if (!text) { // couldn't load file... fixup path for relative reference and retry...
var h=document.location.href;
var text=loadFile(getLocalPath(decodeURIComponent(h.substr(0,h.lastIndexOf("/")+1)))+src);
}
if (text) { // test it again... if file was loaded OK, render it in a class wrapper
if (fallback.length) // create new tiddler using primary source name (if any)
addTiddler(src,text,tids.length?tids:[fallback]);
var wrapper=createTiddlyElement(place,"span",null,className);
wikify(substitute(extract(text,tids),args),wrapper); // render
break; // stop processing alternatives
}
}
}
};
//}}}
/***
|Name|FileDropPlugin|
|Source|http://www.TiddlyTools.com/#FileDropPlugin|
|Version|2.1.4|
|Author|BradleyMeck, Eric Shulman, and Kenny Z|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|drag-and-drop files/directories to create tiddlers|
''requires FireFox or another Mozilla-compatible browser.''
!!!!!Configuration
<<<
__FileDropPlugin options:__
<<option chkFileDropContent>>Use Binary Mode?
File Size Limit: <<option txtFileDropDataLimit>> bytes
//(note: excess text content will be truncated, oversized binary files will skipped, 0=no limit)//
<<option chkFileDropLink>>Generate external links to files, using this format:{{editor{<html><nowiki><textarea rows="4" onchange="
config.macros.option.propagateOption('txtFileDropLinkFormat','value',this.value.escapeLineBreaks(),'input');
"></textarea></html><<tiddler {{
var ta=place.lastChild.getElementsByTagName('textarea')[0];
var v=config.options.txtFileDropLinkFormat.unescapeLineBreaks();
ta.value=v;
"";}}>>}}}<<option chkFileDropTrimFilename>>Omit file extensions from tiddler titles
<<option chkFileDropDisplay>>Automatically display newly created tiddlers
Tag newly created tiddlers with: <<option txtFileDropTags>>
__FileDropPlugin+AttachFilePlugin options:__ //(binary file data as encoded 'base64' text)//
<<option chkFileDropAttachLocalLink>> attachment includes reference to local path/filename
>Note: if the plugin does not seem to work, enter ''about:config'' in the Firefox address bar, and make sure that {{{signed.applets.codebase_principal_support}}} is set to ''true''
<<<
!!!!!Usage
<<<
This plugin automatically creates tiddlers from files that are dropped onto an open TiddlyWiki document. You can drop multiple selected files and/or folders to create many tiddlers at once. New tiddler titles are created using the filename of each dropped file (i.e., omitting the path). If a title is already in use, you are prompted to enter a new title for that file. If you drop a folder, you will be asked if you want to create a simple 'directory list' of files in a single tiddler or create one tiddler for each file in that folder.
By default, it is assumed that all dropped files contain text. However, if [[AttachFilePlugin]], [[AttachFilePluginFormatters]] and [[AttachFileMIMETypes]] are installed, then you can drop ''//binary data files//'' as well as text files. If the MIME type of a dropped file is not "text/plain", then AttachFilePlugin is used to create an 'attachment' tiddler, rather than creating a simple text tiddler.
When creating text tiddlers, you can embed a //link// to the original external file at the top of the new tiddler, in addition to (or instead of) the text content itself. The format for this link (see Configuration, below) uses embedded ''//replacement markers//'' that allow you to generate a variety of wiki-formatted output, where:
*%0 = filename (without path)
*%1 = local """file://...""" URL
*%2 = local path and filename (OS-native format)
*%3 = relative path (if subdirectory of current document directory)
*%4 = file size
*%5 = file date
*%6 = current date
*%7 = current ~TiddlyWiki username
*\n = newline
By default, the link format uses the filename (%0) and local URL (%1), enclosed within a //hidden section// syntax, like this:
{{{
/%
!link
[[%0|%1]]
!end
%/
}}}
This permits the link to be embedded along with the text content, without changing the appearance of that content when the tiddler is viewed. To display the link in your tiddler content, use:
{{{
<<tiddler TiddlerName##link>>
}}}
<<<
!!!!!Examples (custom handler functions)
<<<
Adds a single file with confirmation and prompting for title:
{{{
config.macros.fileDrop.addEventListener('application/x-moz-file',
function(nsiFile) {
var msg='You have dropped the file:\n'
+nsiFile.path+'\n'
+'onto the page, it will be imported as a tiddler. Is that ok?'
if(confirm(msg)) {
var newDate = new Date();
var title = prompt('what would you like to name the tiddler?');
store.saveTiddler(title,title,loadFile(nsiFile.path),config.options.txtUserName,newDate,[]);
}
return true;
});
}}}
Adds a single file without confirmation, using path/filename as tiddler title:
{{{
config.macros.fileDrop.addEventListener('application/x-moz-file',
function(nsiFile) {
var newDate = new Date();
store.saveTiddler(nsiFile.path,nsiFile.path,loadFile(nsiFile.path),config.options.txtUserName,newDate,[]);
story.displayTiddler(null,nsiFile.path)
return true;
});
}}}
<<<
!!!!!Revisions
<<<
2010.03.06 2.1.4 added event listener for 'dragover' (for FireFox 3.6+)
2009.10.10 2.1.3 fixed IE code error
2009.10.08 2.1.2 fixed chkFileDropContent bypass handling for binary attachments
2009.10.07 2.1.0 added chkFileDropContent and chkFileDropLink/txtFileDropLinkFormat
2009.08.19 2.0.0 fixed event listener registration for FireFox 3.5+. Also, merged with FileDropPluginConfig, with code cleanup/reduction
2008.08.11 1.5.1 added chkFileDropAttachLocalLink option to allow suppression of local path/file link
2007.xx.xx *.*.* add suspend/resume of notifications to improve performance when multiple files are handled
2007.01.01 0.9.9 extensions for AttachFilePlugin
2006.11.04 0.1.1 initial release by Bradley Meck
<<<
!!!!!Code
***/
//{{{
version.extensions.FileDropPlugin={major:2, minor:1, revision:4, date: new Date(2010,3,6)};
config.macros.fileDrop = {
customDropHandlers: [],
addEventListener: function(paramflavor,func,inFront) {
var obj={}; obj.flavor=paramflavor; obj.handler=func;
if (!inFront) this.customDropHandlers.push(obj);
else this.customDropHandlers.shift(obj);
},
dragDropHandler: function(evt) {
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
var dragService = Components.classes['@mozilla.org/widget/dragservice;1'].getService(Components.interfaces.nsIDragService);
var dragSession = dragService.getCurrentSession();
var transferObject = Components.classes['@mozilla.org/widget/transferable;1'].createInstance();
transferObject = transferObject.QueryInterface(Components.interfaces.nsITransferable);
transferObject.addDataFlavor('application/x-moz-file');
var numItems = dragSession.numDropItems;
if (numItems>1) {
clearMessage();
displayMessage('Reading '+numItems+' files...');
store.suspendNotifications();
}
for (var i = 0; i < numItems; i++) {
dragSession.getData(transferObject, i);
var dataObj = {};
var dropSizeObj = {};
for(var ind=0; ind<config.macros.fileDrop.customDropHandlers.length; ind++) {
var item = config.macros.fileDrop.customDropHandlers[ind];
if(dragSession.isDataFlavorSupported(item.flavor)) {
transferObject.getTransferData(item.flavor, dataObj, dropSizeObj);
var droppedFile = dataObj.value.QueryInterface(Components.interfaces.nsIFile);
var result = item.handler.call(item,droppedFile);
evt.stopPropagation();
evt.preventDefault();
if (result) break;
}
}
}
if (numItems>1) {
store.resumeNotifications();
store.notifyAll();
displayMessage(numItems+' files have been processed');
}
}
}
//}}}
/***
!!!!!window event handlers
***/
//{{{
if(!window.event) {
window.addEventListener('dragdrop', // FireFox3.1-
config.macros.fileDrop.dragDropHandler, true);
window.addEventListener('drop', // FireFox3.5+
config.macros.fileDrop.dragDropHandler, true);
window.addEventListener('dragover', // FireFox3.6+
function(e){e.stopPropagation();e.preventDefault();}, true);
}
//}}}
/***
!!!!!handler for files, directories and binary attachments (see [[AttachFilePlugin]])
***/
//{{{
var defaults={
chkFileDropDisplay: true,
chkFileDropTrimFilename: false,
chkFileDropContent: true,
chkFileDropLink: true,
txtFileDropLinkFormat: '/%\\n!link\\n[[%0|%1]]\\n!end\\n%/',
txtFileDropDataLimit: '32768',
chkFileDropAttachLocalLink: true,
txtFileDropTags: ''
};
for (var id in defaults) if (config.options[id]===undefined)
config.options[id]=defaults[id];
config.macros.fileDrop.addEventListener('application/x-moz-file',function(nsiFile) {
var co=config.options; // abbrev
var header='Index of %0\n^^(as of %1)^^\n|!filename| !size | !modified |\n';
var item='|[[%0|%1]]| %2|%3|\n';
var footer='Total of %0 bytes in %1 files\n';
var now=new Date();
var files=[nsiFile];
if(co.txtFileDropDataLimit==0) co.txtFileDropDataLimit ='';
if (nsiFile.isDirectory()) {
var folder=nsiFile.directoryEntries;
var files=[];
while (folder.hasMoreElements()) {
var f=folder.getNext().QueryInterface(Components.interfaces.nsILocalFile);
if (f instanceof Components.interfaces.nsILocalFile && !f.isDirectory()) files.push(f);
}
var msg=nsiFile.path.replace(/\\/g,'/')+'\n\n';
msg+='contains '+files.length+' files... ';
msg+='select OK to attach all files or CANCEL to create a list...';
if (!confirm(msg)) { // create a list in a tiddler
var title=nsiFile.leafName; // tiddler name is last directory name in path
while (title && title.length && store.tiddlerExists(title)) {
if (confirm(config.messages.overwriteWarning.format([title]))) break;
title=prompt('Enter a new tiddler title',nsiFile.path.replace(/\\/g,'/'));
}
if (!title || !title.length) return true; // cancelled
var text=header.format([nsiFile.path.replace(/\\/g,'/'),now.toLocaleString()]);
var total=0;
for (var i=0; i<files.length; i++) { var f=files[i];
var name=f.leafName;
if (co.chkFileDropTrimFilename)
{ var p=name.split('.'); if (p.length>1) p.pop(); name=p.join('.'); }
var path='file:///'+f.path.replace(/\\/g,'/');
var size=f.fileSize; total+=size;
var when=new Date(f.lastModifiedTime).formatString('YYYY.0MM.0DD 0hh:0mm:0ss');
text+=item.format([name,path,size,when]);
}
text+=footer.format([total,files.length]);
var newtags=co.txtFileDropTags?co.txtFileDropTags.readBracketedList():[];
store.saveTiddler(null,title,text,co.txtUserName,when,newtags);
if (co.chkFileDropDisplay) story.displayTiddler(null,title);
return true;
}
}
if (files.length>1) store.suspendNotifications();
for (i=0; i<files.length; i++) {
var append=false; var overwrite=false;
var file=files[i];
if (file.isDirectory()) continue; // skip over nested directories
var type='text/plain';
var title=file.leafName; // tiddler name is file name
if (co.chkFileDropTrimFilename)
{ var p=title.split('.'); if (p.length>1) p.pop(); title=p.join('.'); }
var name=file.leafName;
var path=file.path;
var url='file:///'+path.replace(/\\/g,'/');
var size=file.fileSize;
var when=new Date(file.lastModifiedTime);
var now=new Date();
var who=config.options.txtUserName;
var h=document.location.href;
var cwd=getLocalPath(decodeURIComponent(h.substr(0,h.lastIndexOf('/')+1)));
var relpath=path.startsWith(cwd)?'./'+path.substr(cwd.length):path;
while(title && title.length && store.tiddlerExists(title)) {
var tt=prompt('Tiddler '+title+' already exists, Press:\nA - Append (text only),\nO - Overwrite,\nR - Rename');
if(!tt||!tt.length){title=null;break;};
switch(tt){
case 'A':
case 'a': append=true; break;
case 'O':
case 'o': overwrite=true; break;
case 'R':
case 'r': tt=prompt('Enter a new tiddler title',path.replace(/\\/g,'/')); if(tt) title=tt; continue;
default: continue;
}
break;
}
if (!title || !title.length) continue; // cancelled
if (co.chkFileDropContent && config.macros.attach.getMIMEType) {
type=config.macros.attach.getMIMEType(name,'');
if (!type.length)
type=prompt('Unknown file type. Enter a MIME type','text/plain');
if (!type||!type.length) continue; // cancelled
}
var newtags=co.txtFileDropTags?co.txtFileDropTags.readBracketedList():[];
if (type=='text/plain' || !co.chkFileDropContent) {
//displayMessage("plain text");
var txt='';
var fmt=co.txtFileDropLinkFormat.unescapeLineBreaks();
var out=loadFile(path);
if (co.chkFileDropLink)
txt+=fmt.format([name,url,path,relpath,size,when,now,who]);
var lim=co.txtFileDropDataLimit;
txt+=(lim)?out.substr(0,lim):out;
if (lim && size>lim){
txt+='\n----\nfilesize ('+size+')'
+' is larger than FileDrop limit ('+lim+')...\n'
+'additional content has been omitted';
displayMessage(name+"'s filesize is over the limit");
alert(name+"'s filesize is over the limit");
}
if(!append) { // save or overwrite
store.saveTiddler(null,title,txt,co.txtUserName,when,newtags);
if(overwrite) displayMessage(title+' overwritten');
else displayMessage(title+' saved');
}
else{ //Append
store.getTiddler(title).text += '\n----\n' + txt;
story.refreshTiddler(title,null,true);
store.setDirty(true); autoSaveChanges();
displayMessage(title+' appended');
}
} else { // if binary file
//displayMessage("embedded");
//var embed=co.chkFileDropContent && ((!co.txtFileDropDataLimit) || (size<co.txtFileDropDataLimit));
var embed=((!co.txtFileDropDataLimit) || (size<co.txtFileDropDataLimit));
if(embed){ newtags.push('attachment'); newtags.push('excludeMissing');}
config.macros.attach.createAttachmentTiddler(path,now.formatString(config.macros.timeline.dateFormat),'attached by FileDropPlugin',newtags,title,embed,co.chkFileDropAttachLocalLink,false,url,'',type,co.chkFileDropDisplay);
}
if (co.chkFileDropDisplay) story.displayTiddler(null,title);
}
if (files.length>1) { store.resumeNotifications(); store.notifyAll(); }
return true;
})
//}}}
<<myComment>>
----
~~:::::__Fri Jun 25 2010 19:54:40 GMT-0400 (Eastern Daylight Time)__:::::~~
Changes:
* Added append feature.
* Improved the look&feel of prompts if tiddler already exists w/ same title.
* creation date changed to use variable "when" instead of "now".
----
~~:::::__Fri Jun 25 2010 19:55:56 GMT-0400 (Eastern Daylight Time)__:::::~~
fix:
*the original uses var relpath, I changed it to url in the last else block where config.macros.attach.createAttachmentTiddler was called. This seem to fix the linking issue.
----
~~:::::__Fri Jun 25 2010 19:57:01 GMT-0400 (Eastern Daylight Time)__:::::~~
added: allert & display message added when fileSize exceeds sizeLimit, which result in data loss.
----
~~:::::__Fri Jun 25 2010 20:01:31 GMT-0400 (Eastern Daylight Time)__:::::~~
unsure: Some confusion over configurations. Made alot of change to the last if/else block where binary/text mode are selected. Removed MIME type checking when in text mode. hmmm... Error when limit is set to zero, this is suppose to mean unlimited. However, it always evaluates to false. So I added {{{if(XXXXX=0) XXXX=null}}}, this seem to fix the js undefine/0/false issue.
/***
|Name|FoldHeadingsPlugin|
|Source|http://www.TiddlyTools.com/#FoldHeadingsPlugin|
|Version|1.1.2|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|automatically turn headings into slider-like panels that can be folded/unfolded with a single click|
This plugin defines a macro that automatically converts heading-formatted content into sliders that let you expand/collapse their content by clicking on individual headings.
!!!!!Usage
<<<
{{{
<<foldHeadings opened|closed tag tag tag...>>
}}}
where: ''opened'' or ''closed'' is a keyword indicating the initial state of the sections (default: opened), and ''tag tag tag...'' is an optional list of tags to match, so that the foldable effect is only applied to tiddlers that contain one (or more) of the indicated tags.
When you place the macro in a tiddler, any heading-formatted content (i.e, "!" through "!!!!!") in that tiddler will automatically become //'fold-able'//, allowing you to expand/collapse the content that follows each heading simply by clicking on that heading. Each content section begins with the first element following a heading, and continues until either another heading is found or the end of the tiddler is reached. For example:
{{{
<<foldHeadings closed>>
}}}
is embedded in ''this'' tiddler in order to make all the headings it contains 'fold-able'. Note that the macro has been placed at the //end// of the tiddler because it only operates on *rendered* content. Thus, only headings that //precede// it in the same tiddler will become fold-able, as any headings that //follow// it are not actually rendered until //after// the macro has been processed.
You can further limit the effect of the macro within the tiddler by surrounding several headings in a "CSS class wrapper" ("""{{classname{...}}}""") or other containing DOM element (e.g., """@@display:inline;...@@""") and then embedding the {{{<<foldHeadings>>}}} macro inside that container (at the end)... only those headings that are also within that container will be made fold-able, instead of converting ''all'' the headings in that tiddler.
Conversely, if you want the fold-able ability to apply to the headings in //all// tiddlers, ''without having to alter //any// of those individual tiddlers'', you can add the macro to the end of your [[ViewTemplate]], so that it will be invoked after the content in each tiddler has been rendered, causing all headings they contain to automatically become fold-able. For example:
{{{
<span macro="foldHeadings closed"></span>
}}}
You can also limit this effect to selected tiddlers by specifying one or more tags as additional macro parameters. For example:
{{{
<span macro="foldHeadings closed systemConfig"></span>
}}}
is only applied to headings contained in //plugin tiddlers// (i.e., tiddlers tagged with <<tag systemConfig>>), while headings in other tiddlers remain unaffected by the macro, even though it is embedded in the common [[ViewTemplate]] definition.
<<<
!!!!!Revisions
<<<
2009.11.30 [1.1.2] corrected CSS 'text-weight' to 'font-weight'
2009.01.06 [1.1.1] removed hijack of scrollToSection() (see [[SectionLinksPlugin]] for equivalent code)
2008.11.17 [1.1.0] added hijack of 'scrollToSection()' function (see [[CoreTweaks]] and http://trac.tiddlywiki.org/ticket/784)
2007.12.06 [1.0.2] fix handling for empty sections when checking for sliderPanel/floatingPanel
2007.12.02 [1.0.1] fix handling when content following a heading is already a sliderPanel/floatingPanel
2007.12.01 [1.0.0] initial release
<<<
!!!!!Code
***/
//{{{
version.extensions.FoldHeadingsPlugin= {major: 1, minor: 1, revision: 2, date: new Date(2009,11,30)};
config.macros.foldHeadings = {
guideText: "opened|closed className",
showtip: "click to show '%0'",
hidetip: "click to hide '%0'",
showlabel: "more...",
hidelabel: "[x]",
html: "<span style='float:right;font-weight:normal;font-size:80%;' class='TiddlyLinkExisting'>%0 </span>",
handler: function(place,macroName,params) {
var show=params[0] && params.shift().toLowerCase()!="closed";
if (params.length) { // if filtering by tag(s)
var here=story.findContainingTiddler(place);
if (here) var tid=store.getTiddler(here.getAttribute("tiddler"));
if (!tid || !tid.tags.containsAny(params)) return; // in a tiddler and not tagged... do nothing...
}
var elems=place.parentNode.getElementsByTagName("*");
var heads=[]; for (var i=0; i<elems.length; i++) { // get non-foldable heading elements
var n=elems[i].nodeName; var foldable=hasClass(elems[i],"foldable");
if ((n=="H1"||n=="H2"||n=="H3"||n=="H4"||n=="H5")&&!foldable)
heads.push(elems[i]);
}
for (var i=0; i<heads.length; i++) { var h=heads[i]; // for each heading element...
// find start/end of section content (up to next heading or end of content)
var start=end=h.nextSibling; while (end && end.nextSibling) {
var n=end.nextSibling.nodeName.toUpperCase();
if (n=="H1"||n=="H2"||n=="H3"||n=="H4"||n=="H5") break;
end=end.nextSibling;
}
if (start && hasClass(start,"sliderPanel")||hasClass(start,"floatingPanel")) continue; // heading is already a slider!
var span=createTiddlyElement(null,"span",null,"sliderPanel"); // create container
span.style.display=show?"inline":"none"; // set initial display state
h.parentNode.insertBefore(span,start); // and insert it following the heading element
// move section elements into container...
var e=start; while (e) { var next=e.nextSibling; span.insertBefore(e,null); if (e==end) break; e=next; }
// set heading label/tip/cursor...
h.title=(show?this.hidetip:this.showtip).format([h.textContent])
h.innerHTML=this.html.format([show?this.hidelabel:this.showlabel])+h.innerHTML;
h.style.cursor='pointer';
addClass(h,"foldable"); // so we know it been done (and to add extra styles)
h.onclick=function() {
var panel=this.nextSibling; var show=panel.style.display=="none";
// update panel display state
if (config.options.chkAnimate) anim.startAnimating(new Slider(panel,show));
else panel.style.display = show?"inline":"none";
// update heading label/tip
this.removeChild(this.firstChild); // remove existing label
var fh=config.macros.foldHeadings; // abbreviation for readability...
this.title=(show?fh.hidetip:fh.showtip).format([this.textContent])
this.innerHTML=fh.html.format([show?fh.hidelabel:fh.showlabel])+this.innerHTML;
}
}
}
}
if (story.scrollToSection) {
Story.prototype.foldheadings_scrollToSection=Story.prototype.scrollToSection;
Story.prototype.scrollToSection=function(title,section) {
var e=this.foldheadings_scrollToSection.apply(this,arguments);
// if scrolling to a folded section heading, click to expand it
if (e && hasClass(e,'foldable') && e.nextSibling.style.display=='none') e.onclick();
}
}
//}}}
// //<<foldHeadings closed>>
/***
|''Name:''|FootnotesPlugin|
|''Description:''|Create automated tiddler footnotes.|
|''Author:''|Saq Imtiaz ( lewcid@gmail.com )|
|''Source:''|http://tw.lewcid.org/#FootnotesPlugin|
|''Code Repository:''|http://tw.lewcid.org/svn/plugins|
|''Version:''|2.01|
|''Date:''|10/25/07|
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|
|''~CoreVersion:''|2.2.2|
!!Usage:
*To create a footnote, just put the footnote text inside triple backticks.
*Footnotes are numbered automatically, and listed at the bottom of the tiddler.
*{{{Creating a footnote is easy. ```This is the text for my footnote```}}}
*[[FootnotesDemo|http://tw.lewcid.org/#FootnotesDemo]]
***/
// /%
//!BEGIN-PLUGIN-CODE
config.footnotesPlugin = {
backLabel: " ^",
backLabelTip: "back",
};
config.formatters.unshift( {
match: "```",
lookaheadRegExp: /```((?:.|\n)*?)```/g,
handler: function(w)
{
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source);
if(lookaheadMatch && lookaheadMatch.index == w.matchStart )
{
var tiddler = story.findContainingTiddler(w.output);
if (!tiddler.notes)
tiddler.notes = [];
var title = tiddler.getAttribute("tiddler");
tiddler.notes.pushUnique(lookaheadMatch[1]);
var pos = tiddler.notes.indexOf(lookaheadMatch[1]) + 1;
createTiddlyButton(w.output,pos,lookaheadMatch[1],function(){var x=document.getElementById(title+"ftn"+pos);window.scrollTo(0,ensureVisible(x)+(ensureVisible(x)<findScrollY()?(findWindowHeight()-x.offsetHeight):0));return false;},"ftnlink",title+"ftnlink"+pos);
w.nextMatch = lookaheadMatch.index + lookaheadMatch[0].length;
}
}
});
old_footnotes_refreshTiddler = Story.prototype.refreshTiddler;
Story.prototype.refreshTiddler = function(title,template,force)
{
var tiddler = old_footnotes_refreshTiddler.apply(this,arguments);
if (tiddler.notes && tiddler.notes.length)
{
var holder = createTiddlyElement(null,"div",null,"footnoteholder");
var list = createTiddlyElement(holder,"ol",title+"footnoteholder");
for (var i=0; i<tiddler.notes.length; i++)
{
var ftn = createTiddlyElement(list,"li",title+"ftn"+(i+1),"footnote");
wikify(tiddler.notes[i]+" ",ftn);
createTiddlyButton(ftn," ^","back",function(){window.scrollTo(0,ensureVisible(document.getElementById(this.parentNode.id.replace("ftn","ftnlink"))));return false;},"ftnbklink");
}
var count = tiddler.childNodes.length;
for (var j=0; j<count; j++){
if(hasClass(tiddler.childNodes[j],"viewer")){
var viewer = tiddler.childNodes[j];
}
}
viewer.appendChild(holder);
tiddler.notes = [];
}
return tiddler;
};
setStylesheet(
".tiddler a.ftnlink {vertical-align: super; font-size: 0.8em; color:red;}\n"+
".tiddler a.ftnlink:hover, .tiddler .footnoteholder a.ftnbklink:hover{color:#fff;background:red;}\n"+
".tiddler div.footnoteholder{margin:1.8em 1.0em; padding:0.1em 1.0em 0.1em 1.0em ;border-left: 1px solid #ccc;}"+
".tiddler footnoteholder ol {font-size: 0.9em; line-height: 1.2em;}\n"+
".tiddler .footnoteholder li.footnote {margin: 0 0 5px 0;}\n"+
".tiddler .footnoteholder a.ftnbklink{color:red;}\n","FootNotesStyles");
//!END-PLUGIN-CODE
// %/
<<myComment>>
----
~~:::::__Fri Jun 25 2010 21:38:29 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Changed to: Footnotes show up as tooltips as well as appear at the bottom.
----
~~:::::__Fri Jun 25 2010 21:38:50 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ can't upload to tiddlyspot.com when footnotesplugin is turned on... need to compare try the original.
----
~~:::::__Tue Jun 29 2010 19:50:19 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Now I can upload, but seems to conflict with TrashPlugin.
//{{{
function getExternalText(url){
if(window.Components && window.netscape && window.netscape.security && document.location.protocol.indexOf("http") == -1)
window.netscape.security.PrivilegeManager.enablePrivilege("UniversalBrowserRead");
this.xmlhttp = null;
if ( window.XMLHttpRequest ) this.xmlhttp = new XMLHttpRequest();
else if ( window.ActiveXObject ) {
try { // Works well in IE Browser's
xmlhttp= new ActiveXObject("Microsoft.XMLHTTP");
} catch( e ) {
xmlhttp= new ActiveXObject("Msxml2.XMLHTTP");
}
}
try{ // in case bad feeds
this.xmlhttp.open("GET", url, false); // wait till finish
this.xmlhttp.send(null);
}
catch(e) {
alert('Could Not Process Feed URL: ' + url);
}
return this.xmlhttp.responseText;
}
function getQuoteOfTheDay(){
url="http://img.tfd.com/daily/quote.js";
text=getExternalText(url);
text=text.substring(22,text.indexOf("</table>';"));
return "<html>"+text+"</table></html>";
}
//}}}
My personal collection of plugins and memo on editing ~TiddlyWiki. Most changes made to plugins are logged.
<<option chkDisableTabsBar>> Disable the tabs bar
[[How to's|howto]]
/***
<<history>>
|''Name:''|HistoryPlugin|
|''Description:''|Add history or revision control to any individual tiddler.|
|''Author:''|MartinBudden, TonyGarnockJones, and Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#HistoryPlugin|
|''Dependencies:''|[[json2]] [[graph]] [[fs]] [[Draw]] [[diff]]|
|''CodeRepository:''|[[HistoryPluginRequired.zip|http://cooltool.tiddlyspot.com/#HistoryPluginRequired.zip]],|
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|July 3, 2010|
|''Comments:''|[[The original code|http://homepages.kcbbs.gen.nz/tonyg/projects/synchrotron.html]] keeps track of changes to the entire TW. I changed it so each tiddler has its own repository. This gives it that timeline or "history" functionality I was going for.|
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Add history or revision control to any individual tiddler. Be able to check for changes in different revisions.
!!Usage
#Import
#Save & Reload
#Add {{{<<history>>}}} to any tiddler.
#Click commit button after writing first draft.
!Todo
*Find and remove rogue revision repositories.
!!Code
***/
//{{{
if(!version.extensions.HistoryPlugin) {
version.extensions.HistoryPlugin= {installed:true};
config.macros.history={
canvis: [],
init: function(){
config.shadowTiddlers.StyleSheetForHistory = this.css;
setStylesheet(store.getTiddlerText("StyleSheetForHistory",this.css),"history");
},
handler: function(place,macroName,params,wikifier,paramString,tiddler){
var rev = new Revision(tiddler);
var div=createTiddlyElement(place,'div',null,'history');
DrawDvcs.tiddlyRenderRepository(div,rev.repo,rev);
createTiddlyElement(div,'br');
if(rev.dirty)
createTiddlyButton(div,"commit","Commit the change",function(){rev.commit()});
if(this.canvis[rev.inode])
createTiddlyButton(div,"canvis","Temporary unsaved changes",
function(){
if(rev.dirty){ //clone & swap
temp = config.macros.history.copy(tiddler.text,tiddler.fields.hist_uuid);
tiddler.text=config.macros.history.canvis[rev.inode].text;
tiddler.fields.hist_uuid=config.macros.history.canvis[rev.inode].uuid;
config.macros.history.canvis[rev.inode]=temp;
}else{
tiddler.text = config.macros.history.canvis[rev.inode].text;
tiddler.fields.hist_uuid = config.macros.history.canvis[rev.inode].uuid;
config.macros.history.canvis[rev.inode] = null;
}
story.refreshTiddler(tiddler.title,null,true);
});
return false;
},
copy: function(text,uuid){
t={}; t.text=text; t.uuid=uuid; return t;
},
css: "div.history{float:right; margin:4px;}\n\
div.repository{line-height:0px;white-space:nowrap;}\n\
.revision.selected{background-color:blue;color:white;}\n\
.revision.modified{background-color:red;color:white;}\n",
//.revision.aParent{background-color:#00cc00;color:white;}\n", // NEVER USED
};
// draw diagram of revision paths
DrawDvcs.tiddlyRenderRepository = function(place,repo,revStore) {
var para=createTiddlyElement(place,'div',null,'repository');
var ordering = DrawDvcs.renderRepository(repo);
for (var i = 0; i < ordering.length; i++){
var item = ordering[i];
var rev = repo.lookupRev(item.revId);
var pictures = item.pictures;
for (var j = 0; j < pictures.length; j++) {
img=createTiddlyElement(para,'img',null,'repoImg');
img.src = config.macros.history.images[pictures[j]];
}
var summary=((rev.metadata||{}).subject)||"Untitled";
var btnCss='revision'; var btnTxt='Checkout';
if(revStore.fs.directParent==item.revId){
if(revStore.dirty) btnCss+=' modified';
else btnCss+=' selected';
btnTxt='Revert';
}//else if(revStore.fs.additionalParent == item.revId) btnCss+=' aParent'; // NEVER HAPPENS
var s=createTiddlyButton(para,summary,btnTxt,revisionClicked,btnCss);
s.revisionId=item.revId; s.revStore=revStore;
createTiddlyElement(para,'br');
}
};
// called when a revision path is clicked
function revisionClicked(event) {
var e = (event || window.event);
var revId = e.target.revisionId;
var revStore = e.target.revStore;
revStore.checkout(revId);
return false;
};
// object holding revisions
function Revision(tiddler){
this.repo = new Dvcs.Repository();
this.fs = this.repo.update(null);
this.tiddler = tiddler;
this.inode = tiddler.fields.hist_inode;
this.uuid = tiddler.fields.hist_uuid;
this.dirty=false;
this.loadRepo();
this.hasChanged();
return this;
};
// convert data saved in tiddler into repo
Revision.prototype.loadRepo = function(){
var repoText = store.getTiddlerText("repo_"+this.inode,null);
if (repoText){
this.repo.importRevisions(eval(repoText));
this.fs=this.repo.update(this.uuid);
}else{
var id=this.fs.createFile();
while(store.tiddlerExists("repo_"+id)){
id=this.fs.createFile();
}
this.inode = this.tiddler.fields.hist_inode = id;
}
};
// save changes into repo
Revision.prototype.commit = function(){
if(!this.dirty)return;
note = prompt("Note this commit: ").substr(0,40); // error if null and returns.
this.fs.setProp(this.inode,"title",this.tiddler.title);
this.fs.setProp(this.inode,"text",this.tiddler.text);
this.fs.setProp(this.inode,"modifier",this.tiddler.modifier);
this.fs.setProp(this.inode,"modified",this.tiddler.modified.getTime());
tags=[];for(i=0;i<this.tiddler.tags.length;i++)
tags.push(String.encodeTiddlyLink(this.tiddler.tags[i]));
this.fs.setProp(this.inode,"tags",tags.join(' '));
this.fs.anyDirty=true;
uuid = this.repo.commit(this.fs,{subject: note});
this.uuid = this.tiddler.fields.hist_uuid = uuid;
this.fs = this.repo.update(uuid);
this.saveRepo();
story.refreshTiddler(this.tiddler.title,null,true);
};
//save repo into a tiddler
Revision.prototype.saveRepo = function(){
title = "repo_"+this.inode;
repoText = uneval(this.repo.exportRevisions());
text = '//{{{\n'+repoText+'\n//}}}\n';
tags = ['excludeLists','excludeSearch','repository'];
store.saveTiddler(title,title,text,this.tiddler.title,new Date(),tags);
autoSaveChanges();
};
//get diff between current text and data in repo
Revision.prototype.hasChanged = function(){
// check text body
txt = Crypto.hexSha1Str(this.tiddler.text);
src = Crypto.hexSha1Str(this.fs.getProp(this.inode,"text",""));
if(txt!=src)return this.dirty=true;
// check title
txt = Crypto.hexSha1Str(this.tiddler.title);
src = Crypto.hexSha1Str(this.fs.getProp(this.inode,"title",""));
return this.dirty=(txt!=src);
};
// take out data from repo
Revision.prototype.checkout = function(uuid){
if(this.dirty){
if(config.macros.history.canvis[this.inode])
if(!confirm("Any uncommitted work would be lost. Are you sure?"))
return false;
config.macros.history.canvis[this.inode]=
config.macros.history.copy(this.tiddler.text,this.uuid);
}
this.uuid = this.tiddler.fields.hist_uuid = uuid;
this.fs = this.repo.update(this.uuid);
thisTitle=this.tiddler.title;
title=this.fs.getProp(this.inode,"title",thisTitle);
text=this.fs.getProp(this.inode,"text","");
who=this.fs.getProp(this.inode,"modifier","UNKNOWN");
when=this.fs.getProp(this.inode,"modified",new Date().getTime());
date=new Date(); date.setTime(parseInt(when));
tags=this.fs.getProp(this.inode,"tags",' ').readBracketedList();
if(title != thisTitle){
for(i=1,s=title;store.tiddlerExists(title);i++){
title=s+' ('+i+')';
}
story.closeTiddler(thisTitle,false,false);
store.saveTiddler(thisTitle,title,text,who,date,tags,this.tiddler.fields);
story.displayTiddler(null,title);
}else this.tiddler.set(null,text,who,date,tags);
story.refreshTiddler(title,null,true);
return true;
};
config.macros.history.images = {
"blob_0.png": ""
,"blob_1.png": ""
,"blob_10.png": ""
,"blob_11.png": ""
,"blob_12.png": ""
,"blob_13.png": ""
,"blob_14.png": ""
,"blob_15.png": ""
,"blob_2.png": ""
,"blob_3.png": ""
,"blob_4.png": ""
,"blob_5.png": ""
,"blob_6.png": ""
,"blob_7.png": ""
,"blob_8.png": ""
,"blob_9.png": ""
,"slide_l.png": ""
,"slide_m.png": ""
,"slide_r.png": ""
,"stick_0.png": ""
,"stick_1.png": ""
,"stick_10.png": ""
,"stick_11.png": ""
,"stick_12.png": ""
,"stick_13.png": ""
,"stick_14.png": ""
,"stick_15.png": ""
,"stick_2.png": ""
,"stick_3.png": ""
,"stick_4.png": ""
,"stick_5.png": ""
,"stick_6.png": ""
,"stick_7.png": ""
,"stick_8.png": ""
,"stick_9.png": ""
};
} //# end of 'install only once'
//}}}
!about
This zip includes: [[json2]], [[graph]], [[fs]], [[diff]], [[Draw]]
**//Draw was renamed from draw//
!usage
{{{[[HistoryPluginRequired.zip|HistoryPluginRequired.zip]]}}}
[[HistoryPluginRequired.zip|HistoryPluginRequired.zip]]
!notes
attached by FileDropPlugin
!type
application/x-zip-compressed
!file
!url
!hiddenData
/%
!data
data:application/x-zip-compressed;base64,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
!endHiddenData
%/
<<myComment>>
----
~~:::::__Sun Jul 04 2010 20:33:22 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ pseudocode for finding rogue tiddlers
for each tiddler that contains the tag "repositor"
get the modifier,
if modifier exists NOT in store,
remove repo tiddler
/***
|''Name:''|abego.IncludePlugin|
|''Version:''|1.0.1 (2007-04-30)|
|''Type:''|plugin|
|''Source:''|http://tiddlywiki.abego-software.de/#IncludePlugin|
|''Author:''|Udo Borkowski (ub [at] abego-software [dot] de)|
|''Documentation:''|[[IncludePlugin Documentation|http://tiddlywiki.abego-software.de/#%5B%5BIncludePlugin%20Documentation%5D%5D]]|
|''Community:''|([[del.icio.us|http://del.icio.us/post?url=http://tiddlywiki.abego-software.de/index.html%23IncludePlugin]]) ([[Support|http://groups.google.com/group/TiddlyWiki]])|
|''Copyright:''|© 2007 [[abego Software|http://www.abego-software.de]]|
|''Licence:''|[[BSD open source license (abego Software)|http://www.abego-software.de/legal/apl-v10.html]]|
|''~CoreVersion:''|2.1.3|
|''Browser:''|Firefox 1.5.0.9 or better; Internet Explorer 6.0|
{{{<<include [url:] tiddlyWikiPath [delay: delayDuration] [hide: hideFlag]>>}}}
|[[IncludeList]] | [[IncludeState]] |
***/
/***
This plugin's source code is compressed (and hidden). Use this [[link|http://tiddlywiki.abego-software.de/archive/IncludePlugin/Plugin-Include-src.1.0.0.js]] to get the readable source code.
***/
///%
if(!window.abego){window.abego={};}var invokeLater=function(_1,_2,_3){return abego.invokeLater?abego.invokeLater(_1,_2,_3):setTimeout(_1,_2);};abego.loadFile=function(_4,_5,_6){var _7=function(_8,_9,_a,_b,_c){return _8?_5(_a,_b,_9):_5(undefined,_b,_9,"Error loading %0".format([_b]));};if(_4.search(/^((http(s)?)|(file)):/)!=0){if(_4.search(/^((.\:\\)|(\\\\)|(\/))/)==0){_4="file://"+_4;}else{var _d=document.location.toString();var i=_d.lastIndexOf("/");_4=_d.substr(0,i+1)+_4;}_4=_4.replace(/\\/mg,"/");}loadRemoteFile(_4,_7,_6);};abego.loadTiddlyWikiStore=function(_f,_10,_11,_12){var _13=function(_14,_15){if(_12){_12(_14,"abego.loadTiddlyWikiStore",_15,_f,_11);}};var _16=function(_17,_18){var _19=_18.indexOf(startSaveArea);var _1a=_18.indexOf("<!--POST-BODY-END--"+">");var _1b=_18.lastIndexOf(endSaveArea,_1a==-1?_18.length:_1a);if((_19==-1)||(_1b==-1)){return config.messages.invalidFileError.format([_f]);}var _1c="<html><body>"+_18.substring(_19,_1b+endSaveArea.length)+"</body></html>";var _1d=document.createElement("iframe");_1d.style.display="none";document.body.appendChild(_1d);var doc=_1d.document;if(_1d.contentDocument){doc=_1d.contentDocument;}else{if(_1d.contentWindow){doc=_1d.contentWindow.document;}}doc.open();doc.writeln(_1c);doc.close();var _1f=doc.getElementById("storeArea");_17.loadFromDiv(_1f,"store");_1d.parentNode.removeChild(_1d);return null;};var _20=function(_21){_13("Error when loading %0".format([_f]),"Failed");_10(undefined,_f,_11,_21);return _21;};var _22=function(_23){_13("Loaded %0".format([_f]),"Done");_10(_23,_f,_11);return null;};var _24=function(_25,_26,_27,_28){if(_25===undefined){_20(_28);return;}_13("Processing %0".format([_f]),"Processing");var _29=config.messages.invalidFileError;config.messages.invalidFileError="The file '%0' does not appear to be a valid TiddlyWiki file";try{var _2a=new TiddlyWiki();var _2b=_16(_2a,_25);if(_2b){_20(_2b);}else{_22(_2a);}}catch(ex){_20(exceptionText(ex));}finally{config.messages.invalidFileError=_29;}};_13("Start loading %0".format([_f]),"Started");abego.loadFile(_f,_24,_11);};(function(){if(abego.TiddlyWikiIncluder){return;}var _2c="waiting";var _2d="loading";var _2e=1000;var _2f=-200;var _30=-100;var _31=-300;var _32;var _33=[];var _34={};var _35=[];var _36;var _37=[];var _38;var _39=function(){if(_32===undefined){_32=config.options.chkUseInclude===undefined||config.options.chkUseInclude;}return _32;};var _3a=function(url){return "No include specified for %0".format([url]);};var _3c=function(){var _3d=_35;_35=[];if(_3d.length){for(var i=0;i<_37.length;i++){_37[i](_3d);}}};var _3f;var _40=function(){if(_36!==undefined){clearInterval(_36);}_3f=0;var _41=function(){abego.TiddlyWikiIncluder.sendProgress("","","Done");};_36=setInterval(function(){_3f++;if(_3f<=10){return;}clearInterval(_36);_36=undefined;abego.TiddlyWikiIncluder.sendProgress("Refreshing...","","");refreshDisplay();invokeLater(_41,0,_2f);},1);};var _42=function(_43){var _44;for(var i=0;i<_33.length;i++){var _46=abego.TiddlyWikiIncluder.getStore(_33[i]);if(_46&&(_44=_43(_46,_33[i]))){return _44;}}};var _47=function(){if(!window.store){return invokeLater(_47,100);}var _48=store.fetchTiddler;store.fetchTiddler=function(_49){var t=_48.apply(this,arguments);if(t){return t;}if(config.shadowTiddlers[_49]!==undefined){return undefined;}if(_49==config.macros.newTiddler.title){return undefined;}return _42(function(_4b,url){var t=_4b.fetchTiddler(_49);if(t){t.includeURL=url;}return t;});};if(_33.length){_40();}};var _4e=function(){if(!window.store){return invokeLater(_4e,100);}var _4f=store.getTiddlerText("IncludeList");if(_4f){wikify(_4f,document.createElement("div"));}};var _50=function(_51){var _52=function(){var _53=store.forEachTiddler;var _54=function(_55){var _56={};var _57;var _58=function(_59,_5a){if(_56[_59]){return;}_56[_59]=1;if(_57){_5a.includeURL=_57;}_55.apply(this,arguments);};_53.call(store,_58);for(var n in config.shadowTiddlers){_56[n]=1;}_56[config.macros.newTiddler.title]=1;_42(function(_5c,url){_57=url;_5c.forEachTiddler(_58);});};store.forEachTiddler=_54;try{return _51.apply(this,arguments);}finally{store.forEachTiddler=_53;}};return _52;};var _5e=function(_5f,_60){return _5f[_60]=_50(_5f[_60]);};abego.TiddlyWikiIncluder={};abego.TiddlyWikiIncluder.setProgressFunction=function(_61){_38=_61;};abego.TiddlyWikiIncluder.getProgressFunction=function(_62){return _38;};abego.TiddlyWikiIncluder.sendProgress=function(_63,_64,_65){if(_38){_38.apply(this,arguments);}};abego.TiddlyWikiIncluder.onError=function(url,_67){displayMessage("Error when including '%0':\n%1".format([url,_67]));};abego.TiddlyWikiIncluder.hasPendingIncludes=function(){for(var i=0;i<_33.length;i++){var _69=abego.TiddlyWikiIncluder.getState(_33[i]);if(_69==_2c||_69==_2d){return true;}}return false;};abego.TiddlyWikiIncluder.getIncludes=function(){return _33.slice();};abego.TiddlyWikiIncluder.getState=function(url){var s=_34[url];if(!s){return _3a(url);}return typeof s=="string"?s:null;};abego.TiddlyWikiIncluder.getStore=function(url){var s=_34[url];if(!s){return _3a(url);}return s instanceof TiddlyWiki?s:null;};abego.TiddlyWikiIncluder.include=function(url,_6f){if(!_39()||_34[url]){return;}var _70=this;_33.push(url);_34[url]=_2c;var _71=function(_72,_73,_74,_75){if(_72===undefined){_34[url]=_75;_70.onError(url,_75);return;}_34[url]=_72;_35.push(url);invokeLater(_3c);};var _76=function(){_34[url]=_2d;abego.loadTiddlyWikiStore(url,_71,null,_38);};if(_6f){invokeLater(_76,_6f);}else{_76();}};abego.TiddlyWikiIncluder.forReallyEachTiddler=function(_77){var _78=function(){store.forEachTiddler(_77);};_50(_78).call(store);};abego.TiddlyWikiIncluder.getFunctionUsingForReallyEachTiddler=_50;abego.TiddlyWikiIncluder.useForReallyEachTiddler=_5e;abego.TiddlyWikiIncluder.addListener=function(_79){_37.push(_79);};abego.TiddlyWikiIncluder.addListener(_40);if(config.options.chkUseInclude===undefined){config.options.chkUseInclude=true;}config.shadowTiddlers.AdvancedOptions+="\n<<option chkUseInclude>> Include ~TiddlyWikis (IncludeList | IncludeState | [[help|http://tiddlywiki.abego-software.de/#%5B%5BIncludePlugin%20Documentation%5D%5D]])\n^^(Reload this ~TiddlyWiki to make changes become effective)^^";config.shadowTiddlers.IncludeState="<<includeState>>";var _7a=function(e,_7c,_7d){if(!anim||!abego.ShowAnimation){e.style.display=_7c?"block":"none";return;}anim.startAnimating(new abego.ShowAnimation(e,_7c,_7d));};abego.TiddlyWikiIncluder.getDefaultProgressFunction=function(){setStylesheet(".includeProgressState{\n"+"background-color:#FFCC00;\n"+"position:absolute;\n"+"right:0.2em;\n"+"top:0.2em;\n"+"width:7em;\n"+"padding-left:0.2em;\n"+"padding-right:0.2em\n"+"}\n","abegoInclude");var _7e=function(){var e=document.createElement("div");e.className="includeProgressState";e.style.display="none";document.body.appendChild(e);return e;};var _80=_7e();var _81=function(_82){removeChildren(_80);createTiddlyText(_80,_82);_7a(_80,true,0);};var _83=function(){invokeLater(function(){_7a(_80,false,_2e);},100,_30);};var _84=function(_85,_86,_87,url,_89){if(_87=="Done"||_87=="Failed"){_83();return;}if(_86=="abego.loadTiddlyWikiStore"){_3f=0;if(_87=="Processing"){_81("Including...");}}else{_81(_85);}};return _84;};abego.TiddlyWikiIncluder.setProgressFunction(abego.TiddlyWikiIncluder.getDefaultProgressFunction());config.macros.include={};config.macros.include.handler=function(_8a,_8b,_8c,_8d,_8e,_8f){_8c=_8e.parseParams("url",null,true,false,true);var _90=parseInt(getParam(_8c,"delay","0"));var _91=_8c[0]["url"];var _92=getFlag(_8c,"hide",false);if(!_92){createTiddlyText(createTiddlyElement(_8a,"code"),_8d.source.substring(_8d.matchStart,_8d.nextMatch));}for(var i=0;_91&&i<_91.length;i++){abego.TiddlyWikiIncluder.include(_91[i],_90);}};config.macros.includeState={};config.macros.includeState.handler=function(_94,_95,_96,_97,_98,_99){var _9a=function(){var s="";var _9c=abego.TiddlyWikiIncluder.getIncludes();if(!_9c.length){return "{{noIncludes{\nNo includes or 'include' is disabled (see AdvancedOptions)\n}}}\n";}s+="|!Address|!State|\n";for(var i=0;i<_9c.length;i++){var inc=_9c[i];s+="|{{{"+inc+"}}}|";var t=abego.TiddlyWikiIncluder.getState(inc);s+=t?"{{{"+t+"}}}":"included";s+="|\n";}s+="|includeState|k\n";return s;};var _a0=function(){removeChildren(div);wikify(_9a(),div);if(abego.TiddlyWikiIncluder.hasPendingIncludes()){invokeLater(_a0,500,_31);}};var div=createTiddlyElement(_94,"div");invokeLater(_a0,0,_31);};var _a2=Tiddler.prototype.isReadOnly;Tiddler.prototype.isReadOnly=function(){return _a2.apply(this,arguments)||this.isIncluded();};Tiddler.prototype.isIncluded=function(){return this.includeURL!=undefined;};Tiddler.prototype.getIncludeURL=function(){return this.includeURL;};var _a3={getMissingLinks:1,getOrphans:1,getTags:1,reverseLookup:1,updateTiddlers:1};for(var n in _a3){_5e(TiddlyWiki.prototype,n);}var _a5=function(){if(abego.IntelliTagger){_5e(abego.IntelliTagger,"assistTagging");}};var _a6=function(){if(config.macros.forEachTiddler){_5e(config.macros.forEachTiddler,"findTiddlers");}};_47();invokeLater(_4e,100);invokeLater(_a5,100);invokeLater(_a6,100);})();
//%/
//s = config.macros.attach.encodeBase64("TEXT");
Title of Tiddler: <<option txtMyTiddlerTitleToDebug>> <<option chkMyAlertDebugger>>Alert?
<script show>
createTiddlyButton(place,"refresh","",function(){story.refreshTiddler("InlineJavascriptFactory",null,true);});
var co=config.options;
if(!co.chkMyAlertDebugger)co.chkMyAlertDebugger=false;
var text=store.getTiddlerText(co.txtMyTiddlerTitleToDebug,"CAN'T FIND TIDDLER");
//------Custom Functions------------------------
function myURIDecoder(str){
return str.replace("\x3c","<").replace("\x3e",">").replace("\x3d","=").replace("\x22","\"").replace("\x26",";");
}
//------CODE HERE-----------------------
//-------------------------------------
text= myURIDecoder(text);
if(config.options.chkMyAlertDebugger) prompt("text: ",text);
</script>
/***
|Name|InlineJavascriptPlugin|
|Source|http://www.TiddlyTools.com/#InlineJavascriptPlugin|
|Documentation|http://www.TiddlyTools.com/#InlineJavascriptPluginInfo|
|Version|1.9.5|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|Insert Javascript executable code directly into your tiddler content.|
''Call directly into TW core utility routines, define new functions, calculate values, add dynamically-generated TiddlyWiki-formatted output'' into tiddler content, or perform any other programmatic actions each time the tiddler is rendered.
!!!!!Revisions
<<<
2009.04.11 [1.9.5] pass current tiddler object into wrapper code so it can be referenced from within 'onclick' scripts
2009.02.26 [1.9.4] in $(), handle leading '#' on ID for compatibility with JQuery syntax
|please see [[InlineJavascriptPluginInfo|http://www.TiddlyTools.com/#InlineJavascriptPluginInfo]] for additional revision details|
2005.11.08 [1.0.0] initial release
<<<
/%
!!!!!Code
***/
//{{{
version.extensions.InlineJavascriptPlugin= {major: 1, minor: 9, revision: 5, date: new Date(2009,4,11)};
config.formatters.push( {
name: "inlineJavascript",
match: "\\<script",
lookahead: "\\<script(?: src=\\\"((?:.|\\n)*?)\\\")?(?: label=\\\"((?:.|\\n)*?)\\\")?(?: title=\\\"((?:.|\\n)*?)\\\")?(?: key=\\\"((?:.|\\n)*?)\\\")?( show)?\\>((?:.|\\n)*?)\\</script\\>",
handler: function(w) {
var lookaheadRegExp = new RegExp(this.lookahead,"mg");
lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = lookaheadRegExp.exec(w.source)
if(lookaheadMatch && lookaheadMatch.index == w.matchStart) {
var src=lookaheadMatch[1];
var label=lookaheadMatch[2];
var tip=lookaheadMatch[3];
var key=lookaheadMatch[4];
var show=lookaheadMatch[5];
var code=lookaheadMatch[6];
if (src) { // external script library
var script = document.createElement("script"); script.src = src;
document.body.appendChild(script); document.body.removeChild(script);
}
if (code) { // inline code
if (show) // display source in tiddler
wikify("{{{\n"+lookaheadMatch[0]+"\n}}}\n",w.output);
if (label) { // create 'onclick' command link
var link=createTiddlyElement(w.output,"a",null,"tiddlyLinkExisting",wikifyPlainText(label));
var fixup=code.replace(/document.write\s*\(/gi,'place.bufferedHTML+=(');
link.code="function _out(place,tiddler){"+fixup+"\n};_out(this,this.tiddler);"
link.tiddler=w.tiddler;
link.onclick=function(){
this.bufferedHTML="";
try{ var r=eval(this.code);
if(this.bufferedHTML.length || (typeof(r)==="string")&&r.length)
var s=this.parentNode.insertBefore(document.createElement("span"),this.nextSibling);
if(this.bufferedHTML.length)
s.innerHTML=this.bufferedHTML;
if((typeof(r)==="string")&&r.length) {
wikify(r,s,null,this.tiddler);
return false;
} else return r!==undefined?r:false;
} catch(e){alert(e.description||e.toString());return false;}
};
link.setAttribute("title",tip||"");
var URIcode='javascript:void(eval(decodeURIComponent(%22(function(){try{';
URIcode+=encodeURIComponent(encodeURIComponent(code.replace(/\n/g,' ')));
URIcode+='}catch(e){alert(e.description||e.toString())}})()%22)))';
link.setAttribute("href",URIcode);
link.style.cursor="pointer";
if (key) link.accessKey=key.substr(0,1); // single character only
}
else { // run script immediately
var fixup=code.replace(/document.write\s*\(/gi,'place.innerHTML+=(');
var c="function _out(place,tiddler){"+fixup+"\n};_out(w.output,w.tiddler);";
try { var out=eval(c); }
catch(e) { out=e.description?e.description:e.toString(); }
if (out && out.length) wikify(out,w.output,w.highlightRegExp,w.tiddler);
}
}
w.nextMatch = lookaheadMatch.index + lookaheadMatch[0].length;
}
}
} )
//}}}
// // Backward-compatibility for TW2.1.x and earlier
//{{{
if (typeof(wikifyPlainText)=="undefined") window.wikifyPlainText=function(text,limit,tiddler) {
if(limit > 0) text = text.substr(0,limit);
var wikifier = new Wikifier(text,formatter,null,tiddler);
return wikifier.wikifyPlain();
}
//}}}
// // GLOBAL FUNCTION: $(...) -- 'shorthand' convenience syntax for document.getElementById()
//{{{
if (typeof($)=='undefined') { function $(id) { return document.getElementById(id.replace(/^#/,'')); } }
//}}}
//%/
/***
|''Name:''|LaunchApplicationPlugin|
|''Author:''|Lyall Pearce|
|''Source:''|http://www.Remotely-Helpful.com/TiddlyWiki/LaunchApplication.html|
|''License:''|[[Creative Commons Attribution-Share Alike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|
|''Version:''|1.4.0|
|''~CoreVersion:''|2.3.0|
|''Requires:''| |
|''Overrides:''| |
|''Description:''|Launch an application from within TiddlyWiki using a button|
!!!!!Usage
<<<
{{{<<LaunchApplication "buttonLabel" "tooltip" "application" ["arguments" ...]>>}}}
{{{<<LaunchApplicationButton "buttonLabel" "tooltip" "application" ["arguments" ...]>>}}}
{{{<<LaunchApplicationLink "buttonLabel" "tooltip" "application" ["arguments" ...]>>}}}
* buttonLabel is anything you like
* tooltip is anything you like
* application is a path to the executable (which is Operating System dependant)
* arguments is any command line arguments the application requires.
* You must supply relative path from the location of the TiddlyWiki OR a fully qualified path
* Forward slashes works fine for Windows
{{{<<LaunchApplication...>>}}} functions the same as {{{<<LaunchApplicationButton...>>}}}
eg.
{{{
<<LaunchApplicationButton "Emacs" "Linux Emacs" "file:///usr/bin/emacs">>
}}}
<<LaunchApplicationButton "Emacs" "Linux Emacs" "file:///usr/bin/emacs">>
{{{
<<LaunchApplicationLink "LocalProgram" "Program relative to Tiddly html file" "localDir/bin/emacs">>
}}}
<<LaunchApplicationLink "LocalProgram" "Program relative to Tiddly html file" "localDir/bin/emacs">>
{{{
<<LaunchApplicationButton "Open Notepad" "Text Editing" "file:///e:/Windows/notepad.exe">>
}}}
<<LaunchApplicationButton "Open Notepad" "Text Editing" "file:///e:/Windows/notepad.exe">>
{{{
<<LaunchApplicationLink "C Drive" "Folder" "file:///c:/">>
}}}
<<LaunchApplicationLink "C Drive" "Folder" "file:///c:/">>
!!!!!Revision History
* 1.1.0 - leveraged some tweaks from from Bradly Meck's version (http://bradleymeck.tiddlyspot.com/#LaunchApplicationPlugin) and the example text.
* 1.2.0 - Make launching work in Linux too and use displayMessage() to give diagnostics/status info.
* 1.3.0 - execute programs relative to TiddlyWiki html file plus fix to args for firefox.
* 1.3.1 - parameters to the macro are properly parsed, allowing dynamic paramters using {{{ {{javascript}} }}} notation.
* 1.4.0 - updated core version and fixed empty tooltip and added launch link capability
<<<
***/
//{{{
version.extensions.LaunchApplication = {major: 1, minor: 4, revision: 0, date: new Date(2007,12,29)};
config.macros.LaunchApplication = {};
config.macros.LaunchApplicationButton = {};
config.macros.LaunchApplicationLink = {};
function LaunchApplication(appToLaunch,appParams) {
if(! appToLaunch)
return;
var tiddlyBaseDir = self.location.pathname.substring(0,self.location.pathname.lastIndexOf("\\")+1);
if(!tiddlyBaseDir || tiddlyBaseDir == "") {
tiddlyBaseDir = self.location.pathname.substring(0,self.location.pathname.lastIndexOf("/")+1);
}
// if Returns with a leading slash, we don't want that.
if(tiddlyBaseDir.substring(0,1) == "/") {
tiddlyBaseDir = tiddlyBaseDir.substring(1);
}
if(appToLaunch.indexOf("file:///") == 0) // windows would have C:\ as the resulting file
{
tiddlyBaseDir = "";
appToLaunch = appToLaunch.substring(8);
}
if (config.browser.isIE) {
// want where the tiddly is actually located, excluding tiddly html file
var theShell = new ActiveXObject("WScript.Shell");
if(theShell) {
// the app name may have a directory component, need that too
// as we want to start with current working dir as the location
// of the app.
var appDir = appToLaunch.substring(0, appToLaunch.lastIndexOf("\\"));
if(! appDir || appDir == "") {
appDir = appToLaunch.substring(0, appToLaunch.lastIndexOf("/"));
}
appParams = appParams.length > 0 ? " \""+appParams.join("\" \"")+"\"" : "";
try {
theShell.CurrentDirectory = decodeURI(tiddlyBaseDir + appDir);
var commandString = ('"' +decodeURI(tiddlyBaseDir+appToLaunch) + '" ' + appParams);
pluginInfo.log.push(commandString);
theShell.run(commandString);
} catch (e) {
displayMessage("LaunchApplication cannot locate/execute file '"+tiddlyBaseDir+appToLaunch+"'");
return;
}
} else {
displayMessage("LaunchApplication failed to create ActiveX component WScript.Shell");
}
} else { // Not IE
// want where the tiddly is actually located, excluding tiddly html file
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
var file = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
var launchString;
try { // try linux/unix format
launchString = decodeURI(tiddlyBaseDir+appToLaunch);
file.initWithPath(launchString);
} catch (e) {
try { // leading slash on tiddlyBaseDir
launchString = decodeURI("/"+tiddlyBaseDir+appToLaunch);
file.initWithPath(launchString);
} catch (e) {
try { // try windows format
launchString = decodeURI(appToLaunch).replace(/\//g,"\\");
file.initWithPath(launchString);
} catch (e) {
try { // try windows format
launchString = decodeURI(tiddlyBaseDir+appToLaunch).replace(/\//g,"\\");
file.initWithPath(launchString);
} catch (e) {
displayMessage("LaunchApplication cannot locate file '"+launchString+"' : "+e);
return;
} // try windows mode
} // try windows mode
}; // try with leading slash in tiddlyBaseDir
}; // try linux/unix mode
try {
if (file.isFile() && file.isExecutable()) {
displayMessage("LaunchApplication executing '"+launchString+"' "+appParams.join(" "));
var process = Components.classes['@mozilla.org/process/util;1'].createInstance(Components.interfaces.nsIProcess);
process.init(file);
process.run(false, appParams, appParams.length);
}
else
{
displayMessage("LaunchApplication launching '"+launchString+"' "+appParams.join(" "));
file.launch(); // No args available with this option
}
} catch (e) {
displayMessage("LaunchApplication cannot execute/launch file '"+launchString+"'");
}
}
};
config.macros.LaunchApplication.handler = function (place,macroName,params,wikifier,paramString,tiddler) {
// 0=ButtonText, 1=toolTip, 2=AppToLaunch, 3...AppParameters
if (params[0] && (params[1] || params[1] == "") && params[2]) {
var theButton = createTiddlyButton(place, getParam(params,"buttonText",params[0]), getParam(params,"toolTip",params[1]), onClickLaunchApplication);
theButton.setAttribute("appToLaunch", getParam(params,"appToLaunch",params[2]));
params.splice(0,3);
theButton.setAttribute("appParameters", params.join(" "));
return;
}
}
config.macros.LaunchApplicationButton.handler = function (place,macroName,params,wikifier,paramString,tiddler) {
config.macros.LaunchApplication.handler (place,macroName,params,wikifier,paramString,tiddler);
}
config.macros.LaunchApplicationLink.handler = function (place,macroName,params,wikifier,paramString,tiddler) {
// 0=ButtonText, 1=toolTip, 2=AppToLaunch, 3...AppParameters
if (params[0] && (params[1] || params[1] == "") && params[2]) {
//var theLink = createExternalLink(place, getParam(params,"buttonText",params[0]));
var theLink = createTiddlyButton(place, getParam(params,"buttonText",params[0]), getParam(params,"toolTip",params[1]), onClickLaunchApplication,"link");
theLink.setAttribute("appToLaunch", getParam(params,"appToLaunch",params[2]));
params.splice(0,3);
theLink.setAttribute("appParameters", params.join(" "));
return;
}
}
function onClickLaunchApplication(e) {
var theAppToLaunch = this.getAttribute("appToLaunch");
var theAppParams = this.getAttribute("appParameters").readMacroParams();
LaunchApplication(theAppToLaunch,theAppParams);
}
//}}}
/***
|''Name:''|LaunchApplicationPluginGUI|
|''Description:''|GUI front-end for LaunchApplicationPlugin|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#LaunchApplicationPluginGUI|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Beta|
|''Date:''|Jan 26, 2010|
|''Comments:''||
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
This is a GUI front-end for the Launch Application Plugin.
!!Usage
#Import
#Save & Reload
!!Code
***/
//{{{
// adds to backstage task (insert before built-in 'importTask')
if (config.tasks) { // for TW2.2b or above
config.tasks.LinkProgramTask = {
text: "LinkProgram",
tooltip: "just testing...",
content: "<<LaunchApplicationPluginGUI>>"
}
config.backstageTasks.splice(config.backstageTasks.indexOf("importTask"),0,"LinkProgramTask");
}
setStylesheet("#fileLoc {width:50%;}\n","LAPGUISytle");
config.macros.LaunchApplicationPluginGUI = {
handler: function(place, macro, params){
var queueSelector = createTiddlyElement(place,"div",null,"queueSelector");
createTiddlyText(queueSelector, "Location: ");
if (config.browser.isGecko) { // FF3 FIXUP
var fileLoc = createTiddlyElement(queueSelector,"input");
fileLoc.setAttribute("id","fileLoc");
fileLoc.setAttribute("name","fileLoc");
fileLoc.setAttribute("type","text");
//fileLoc.setAttribute("style","width:60%");
var btnFixSource = createTiddlyElement(queueSelector,"input");
btnFixSource.setAttribute("type","button");
btnFixSource.setAttribute("value","Choose...");
btnFixSource.setAttribute("onclick","config.macros.LaunchApplicationPluginGUI.askForFilename(document.getElementById('fileLoc'));");
}
else{
// For IE/Opera: Don't work on opera either, it just creates a fake path....
// var fileLoc = createTiddlyElement(queueSelector,"input");
// fileLoc.setAttribute("type","file");
// fileLoc.setAttribute("name","fileLoc");
// fileLoc.setAttribute("id","fileLoc");
// fileLoc.setAttribute("style","width:60%");
var fileLoc = createTiddlyElement(queueSelector,"input");
fileLoc.setAttribute("type","text");
fileLoc.setAttribute("value","browser not supported");
}
var butAddQueue = createTiddlyElement(queueSelector,"input");
butAddQueue.setAttribute("type","button");
butAddQueue.setAttribute("name","butAddQueue");
butAddQueue.setAttribute("value", "Add Link");
butAddQueue.setAttribute("onclick","config.macros.LaunchApplicationPluginGUI.addLink();");
},
addLink: function(){
//Adds link to queue
var tagName = "LinkedProgram";
var btnTip = "";
var fileLoc = document.getElementById('fileLoc').value.replace(/\\/g,'/').trim();
var fileName = fileLoc.substr(fileLoc.lastIndexOf('/')+1);
if (fileLoc == ""){ alert('You must enter all the details'); return;}
var queueTxt = '<<LaunchApplicationButton "'+fileName+'" "'+btnTip+'" "file:///'+fileLoc+'">>';
if(prompt('title: '+fileName,queueTxt)){
if(!store.tiddlerExists(fileName)) {
store.saveTiddler(fileName,fileName,queueTxt,config.options.txtUserName, null, tagName);
autoSaveChanges();
displayMessage("Success: Tiddler created");
story.displayTiddler("top", fileName, DEFAULT_VIEW_TEMPLATE);
}else displayMessage("Fail: Tiddler already exists");
}else displayMessage("Fail: Canceled by user");
},
askForFilename: function(target) {
if (target.value == ""){
var path=getLocalPath(document.location.href);
var p=path.lastIndexOf("/"); if (p==-1) p=path.lastIndexOf("\\"); // Unix or Windows
if (p!=-1) path=path.substr(0,p+1); // remove filename, leave trailing slash
}
else{
var path = target.value;
}
var file="";
var result=window.mozAskForFilename(null,path,file,true); // FF3 FIXUP ONLY
if (target && result.length) // set target field and trigger handling
{ target.value=result; target.onchange(); }
return result;
}
};
//}}}
<<myComment>>
Comment of: [[LaunchApplicationPluginGUI]]
----
~~:::::__Sat Jun 26 2010 14:24:14 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Did I write this?
----
~~:::::__Sat Jun 26 2010 14:24:28 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ To DO: fix overwrite problem.
----
~~:::::__Sat Jun 26 2010 14:40:33 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Fixed ow problem. Added autosave check, and helpful msgs.
Edit shadow tiddler [[TabTimeline]]
__syntax:__
:{{{<<timeline "" #>>}}}
Where # is the number of tiddlers to be shown.
/***
|!Name:| ''@@font-size(large):font-variant(small-caps):~ListAuthorPlugin@@'' |
|!Version:|1.0.1|
|!Location|http://gwsyzygy.googlepages.com/creator.html#ListAuthorPlugin|
|!Author:|GregWalker |
|!Type:|Macro Extension |
|!Requires|~TW2.x|
!Description
<<<
It's a macro for listing by creator or modifier.
<<<
!Examples
|!Source|!Output|h
|{{{<<listByAuthor>>}}}|//lists all tiddlers grouped by creator//|
|{{{<<listByAuthor modifier>>}}}|//lists all tiddlers grouped by modifier//|
|{{{<<listByAuthor creator SomeUser>>}}}|//lists all tiddlers created by ''SomeUser''//|
|{{{<<listByAuthor creator currentUser>>}}}|//lists all tiddlers created by the current user//|
!History
* 13-Jun-06, version 1.0.1, Added support for DisplayTiddlerGlyphsPlugin
* 21-Mar-06, version 1.0.0, initial version
!Code
***/
/*{{{*/
version.extensions.ListAuthorPlugin = { major: 1, minor: 0, revision: 1,
date: new Date(2006,6,13),
source: "http://gwsyzygy.googlepages.com/creator.html#ListAuthorPlugin"
};
config.macros.listByAuthor = {};
config.macros.listByAuthor.handler = function(place,macroName,params)
{
var field = params[0] ? params[0] : "creator";
var filter = params[1]=="currentUser" ? config.options.txtUserName : params[1];
// sort by title first, then by author to end up with author then title.
var tiddlers = store.reverseLookup("tags","excludeLists",false,"title");
tiddlers.sort(function (a,b) {if(a[field] == b[field]) return(0); else return (a[field] < b[field]) ? -1 : +1; });
var lastAuthor = "";
for(var t=0; t<tiddlers.length; t++)
{
var tiddler = tiddlers[t];
var theAuthor = tiddler[field];
if(filter==null || theAuthor==filter)
{
if(theAuthor != lastAuthor)
{
var theAuthorList = document.createElement("ul");
place.appendChild(theAuthorList);
if(filter==null)
createTiddlyElement(theAuthorList,"li",null,"listTitle",tiddler[field]);
lastAuthor = theAuthor;
}
var theAuthorListItem = createTiddlyElement(theAuthorList,"li",null,"listLink",null);
if (config.macros.displayTiddlerGlyphs)
{
config.macros.displayTiddlerGlyphs.createGlyphsElement(theAuthorListItem,tiddler,1);
}
theAuthorListItem.appendChild(createTiddlyLink(place,tiddler.title,true));
}
}
}
/*}}}*/
/***
This plugin is released under the [[Creative Commons Attribution 2.5 License|http://creativecommons.org/licenses/by/2.5/]]
***/
/***
|''Name:''|LoadRemoteFileThroughProxy (previous LoadRemoteFileHijack)|
|''Description:''|When the TiddlyWiki file is located on the web (view over http) the content of [[SiteProxy]] tiddler is added in front of the file url. If [[SiteProxy]] does not exist "/proxy/" is added. |
|''Version:''|1.1.0|
|''Date:''|mar 17, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#LoadRemoteFileHijack|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
***/
//{{{
version.extensions.LoadRemoteFileThroughProxy = {
major: 1, minor: 1, revision: 0,
date: new Date("mar 17, 2007"),
source: "http://tiddlywiki.bidix.info/#LoadRemoteFileThroughProxy"};
if (!window.bidix) window.bidix = {}; // bidix namespace
if (!bidix.core) bidix.core = {};
bidix.core.loadRemoteFile = loadRemoteFile;
loadRemoteFile = function(url,callback,params)
{
var isHttp = document.location.toString().substr(0,4) == "http";
if (isHttp && (url.substr(0,4) == "http")){
var proxy = store.getTiddlerText("SiteProxy", "");
if(proxy==""){
url = url.replace(/^http:\/\//i,'');
proxy = "http://cooltool.tiddlyspot.com/proxy/";
}
url = proxy + url;
}
return bidix.core.loadRemoteFile(url,callback,params);
};
//}}}
!<<QOTD Lotto inline 1000>><<QOTD Lotto inline 1000>><<QOTD Lotto inline 1000>>/%
----
1
----
2
----
3
----
4
----
5
----
6
----
7
----
8
----
9
----
0
----
%/
//[[Home|http://sites.google.com/site/yaup00/Home]]//
//[[contact]]//
//[[To Do List]]//
!!!Debug
[[eval()]]
[[print_r()]]
[[print_r2]]
[[EchoMacro]]
[[InlineJavascriptFactory]]
!!!Logging Script
[[QuickLog]]
[[QAFlashMaker]]
[[QuickNote]]
!!!Plugins
[[My Plugins]]
[[Modified Plugins]]
!!!Docs
[[TiddlyWiki Dev Notes]]
[[Samples]]
[[RSS Feeds]]
[[ExamplePlugin]]
|[[ArchivePlugin]] |Changed archival folder to file name instead of just "archive"|
|[[AttachFilePlugin]] |Hide !data section now.|
|[[FileDropPlugin]] |Fixes some bugs.|
|[[FootnotesPlugin]] |Footnote shows up as tooltip and at the bottom.|
|[[RSSReaderPlugin]] |Put in a limit to the number of feeds shown.|
|[[QuoteOfTheDayPlugin]] |Fixed recursion problem.|
|[[TrashPlugin]]|Delete tiddlers and restore them.|
|Plugin|Description|Demo|
|[[WordCountPlugin]] |Like wc in Unix.|[[Demo|wordCount.png]]|
|[[ReadOnlyPlugin]] |Makes tiddlers read only.|[[Demo|readOnly.png]]|
|[[CopyPlugin]] |Copy one tiddler to another name. Good for backing up.|
|[[MyCommentPlugin]] ||
|[[SessionManagerPlugin]]|Auto save and reload sessions on restart. Save and reload any session manually.|
|[[BugMeNotExitingPlugin]] |Exit quickly without being bugged.|
|[[ClearChangeCountPlugin]]|Clears the change count|[[Demo|clearChangeCount.png]]|
|[[LaunchApplicationPluginGUI]] |Front end for LaunchApplicationPlugin. Adds a command to the backstage.|
|[[UndoChangeBySyncPlugin]] |Downloads files from the server no matter what.|
|[[WebReadOnlyPlugin]]||
|[[ExportCommandPlugin]]|Adds export button to the toolbar|[[Demo|exportCommandPlugin.png]]|
|[[HistoryPlugin]]|Add history or revision control to any individual tiddler.|[[Demo|historyPluginSample]]|
|[[TagEditPlugin]]|Adds a button on the toolbar command to edit tags quickly.|
|[[RenameTiddlerPlugin]]|Adds a button on the toolbar command to rename tiddlers quickly.|
/***
|''Name:''|MyCommentPlugin|
|''Description:''|Metadata for your data|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#MyCommentPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Beta|
|''Date:''|June 25, 2010|
|''Comments:''||
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Add comments to your tiddlers. Metadata for your data.
!!Usage
Add "{{{myComment}}}" to [[ToolbarCommands]] in the ~ViewToolbar slice.
!!Code
***/
//{{{
if(!version.extensions.myComment) {
version.extensions.basicCopy = {installed:true};
config.commands.myComment = {
text: "comment",
tooltip: "Comments on this tiddler",
handler: function(event,src,title) {
var tags = ["comment","excludeLists"];
var cTitle = title + "_comment";
if(!store.tiddlerExists(cTitle)){
if(confirm("No Comment. Would you like to create one?")){
var text = '<<myComment>>\n';
var when = new Date();
store.saveTiddler(null,cTitle,text,title,when,tags,null,true,when,title);
store.setTiddlerTag(title,1,"commented" );
// Notify Commented tiddler
store.addNotification(cTitle,function(cTitle){
if(!store.tiddlerExists(cTitle)){
store.setTiddlerTag(title ,0,"commented" );
store.resetTiddler(title); // clear change count
}
});
// Notify comment tiddler
store.addNotification(title,function(title){
if(!store.tiddlerExists(title)){
store.setTiddlerTag(cTitle ,0,"comment");
store.setTiddlerTag(cTitle ,1,"commentRogue");
displayMessage(cTitle+" tagged as commentRogue.");
}
});
store.resetTiddler(title); // clear change count
autoSaveChanges();
}else{
return;
}
}
story.displayTiddler(null,cTitle,null,true,true);
return false;
},
};
config.macros.myComment= {
DEFAULT_COMMENT_TEMPLATE: '{{{\n<html><form class="comment" \
style="display:inline;margin:0;padding:0;white-space:nowrap;" action="#" \
onsubmit="var dom= document.getElementById(\'TEXTAREAID\'); \
cooltool.comment.postComment(\'TEXTAREAID\',dom); dom.focus()"> \
<input type="reset" value="Clear" style="width:4em" onclick="this.form.TEXTAREAID.focus()" /> \
<input type="button" value="Post" style="width:4em" onclick="this.form.onsubmit();this.form.onsubmit();" /> \
<a href="#" onclick="cooltool.comment.clearComment(\'TEXTAREAID\');" >Clear List</a><br /> \
<textarea id="TEXTAREAID" rows="3" style="width:80%" onkeydown="if(event.keyCode == 16) isShift =true; \
if(isShift==true && event.keyCode == 13){this.form.onsubmit();this.form.onsubmit();return false;}" \
onkeyup="isShift=false"></textarea></form></html>\n}}}',
// I make double onsubmit() because it doesn't seem to set focus back to textarea.
init: function(){
config.shadowTiddlers.CommentTemplate = config.macros.myComment.DEFAULT_COMMENT_TEMPLATE;
},
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
if(tiddler.creator && tiddler.modifier != tiddler.creator){
tiddler.set(null,null,tiddler.creator); // Ensures a link back to topic.
story.refreshTiddler(tiddler.title,DEFAULT_VIEW_TEMPLATE,true);
} // saving not necessary
var text = store.getTiddlerText("CommentTemplate",config.macros.myComment.DEFAULT_COMMENT_TEMPLATE);
text = text.substring(4,text.length-4).replace(/TEXTAREAID/gm,tiddler.title);
wikify(text,place);
},
};
if(!window.cooltool) window.cooltool={};
if(!cooltool.comment) cooltool.comment={};
cooltool.comment.postComment = function(title,text){
var tiddler = store.getTiddler(title);
var when=new Date();
var who=config.options.txtUserName;
if((text=text.value.replace(/^\s+|\s+$/g, ''))=='') return;
tiddler.text+='\n----\n~~:::::__'+when+'__:::::~~\n^^(__'+who+' Wrote:__)^^ '+text;
//store.saveTiddler(title,title,text,tiddler.modifier,when);
story.refreshTiddler(title,DEFAULT_VIEW_TEMPLATE,true);
store.dirty=true; autoSaveChanges();
};
cooltool.comment.clearComment = function(title){
if(confirm('Clear this list and start over?')) {
store.getTiddler(title).text='<<myComment>>\n';
//store.saveTiddler(title,title,text);
story.refreshTiddler(title,null,true);
store.dirty=true; autoSaveChanges();
}
};
} //# end of 'install only once'
//}}}
<<myComment>>
----
~~:::::__Mon Jun 28 2010 14:06:31 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Removed delete hijack function and use notifications instead.
/***
|''Name:''|NoTagsPlugin|
|''Description:''|Find tiddlers without a tags|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#NoTagsPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|July 1, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Ever forget to put a tag on your tiddlers and can't seem to locate it? NoTagsPlugin looks for tiddlers without a tag.
!!Usage
#Import
#Save & Reload
#Add {{{<<noTags>>}}} to [[TabTags]].
!!Code
***/
//{{{
if(!version.extensions.NoTagsPlugin) {
version.extensions.NoTagsPlugin= {installed:true};
config.macros.noTags = {
text: 'noTags',
tooltip: "Show tiddlers with no tags",
list: null,
handler: function(place,macroName,params){
this.list = this.getNoTags();
var info = getTiddlyLinkInfo(this.text);
var ul = createTiddlyElement(place,"ul");
var li = createTiddlyElement(ul,"li");
var btn = createTiddlyButton(li,this.text+ " ("+ this.list.length + ")",
this.tooltip.format([this.text]),this.onClickNoTag,info.classes);
},
getNoTags: function(){
var results = [];
store.forEachTiddler(function(title,tiddler) {
if(tiddler.tags.length==0){
results.push(title);
}
});
results.sort(function(a,b) {return a[0].toLowerCase() < b[0].toLowerCase() ? -1 : (a[0].toLowerCase() == b[0].toLowerCase() ? 0 : +1);});
return results;
},
onClickNoTag: function(ev){
var e = ev || window.event;
var popup = Popup.create(this);
addClass(popup,"taggedTiddlerList");
var tag = "";
if(popup) {
var titles = config.macros.noTags.list;
var lingo = config.views.wikified.tag;
if(titles.length > 0) {
var openAll = createTiddlyButton(createTiddlyElement(popup,"li"),lingo.openAllText.format([tag]),lingo.openAllTooltip,config.macros.noTags.onClickTagOpenAll);
createTiddlyElement(createTiddlyElement(popup,"li",null,"listBreak"),"div");
for(r=0; r<titles.length; r++) {
createTiddlyLink(createTiddlyElement(popup,"li"),titles[r],true);
}
} else {
createTiddlyElement(popup,"li",null,"disabled",lingo.popupNone.format([tag]));
}
}
Popup.show(); e.cancelBubble = true;
if(e.stopPropagation) e.stopPropagation();
return false;
},
onClickTagOpenAll: function(ev){
story.displayTiddlers(null,config.macros.noTags.list,null,false,false);
return false;
},
};
} //# end of 'install only once'
//}}}
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<div class='headerShadow'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
<div class='headerForeground'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
<div id='searchBar' macro='search'></div>
</div>
<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
<div id='sidebar'>
<div id='toggleSideBar' macro='toggleSideBar'></div>
<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='tiddlersBar' refresh='none' ondblclick='config.macros.tiddlersBar.onTiddlersBarAction(event)'></div>
<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->
/***
|''Name:''|PasswordOptionPlugin|
|''Description:''|Extends TiddlyWiki options with non encrypted password option.|
|''Version:''|1.0.2|
|''Date:''|Apr 19, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#PasswordOptionPlugin|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0 (Beta 5)|
***/
//{{{
version.extensions.PasswordOptionPlugin = {
major: 1, minor: 0, revision: 2,
date: new Date("Apr 19, 2007"),
source: 'http://tiddlywiki.bidix.info/#PasswordOptionPlugin',
author: 'BidiX (BidiX (at) bidix (dot) info',
license: '[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D]]',
coreVersion: '2.2.0 (Beta 5)'
};
config.macros.option.passwordCheckboxLabel = "Save this password on this computer";
config.macros.option.passwordInputType = "password"; // password | text
setStylesheet(".pasOptionInput {width: 11em;}\n","passwordInputTypeStyle");
merge(config.macros.option.types, {
'pas': {
elementType: "input",
valueField: "value",
eventName: "onkeyup",
className: "pasOptionInput",
typeValue: config.macros.option.passwordInputType,
create: function(place,type,opt,className,desc) {
// password field
config.macros.option.genericCreate(place,'pas',opt,className,desc);
// checkbox linked with this password "save this password on this computer"
config.macros.option.genericCreate(place,'chk','chk'+opt,className,desc);
// text savePasswordCheckboxLabel
place.appendChild(document.createTextNode(config.macros.option.passwordCheckboxLabel));
},
onChange: config.macros.option.genericOnChange
}
});
merge(config.optionHandlers['chk'], {
get: function(name) {
// is there an option linked with this chk ?
var opt = name.substr(3);
if (config.options[opt])
saveOptionCookie(opt);
return config.options[name] ? "true" : "false";
}
});
merge(config.optionHandlers, {
'pas': {
get: function(name) {
if (config.options["chk"+name]) {
return encodeCookie(config.options[name].toString());
} else {
return "";
}
},
set: function(name,value) {config.options[name] = decodeCookie(value);}
}
});
// need to reload options to load passwordOptions
loadOptionsCookie();
/*
if (!config.options['pasPassword'])
config.options['pasPassword'] = '';
merge(config.optionsDesc,{
pasPassword: "Test password"
});
*/
//}}}
/%
!info
Supermemo QA Format
{{{<<tiddler QAFlashMaker with: Worklog_YYYY-0MM-0DD "worklog">>}}}
<<tiddler QAFlashMaker with: Worklog_YYYY-0MM-0DD "worklog">>
//Shortcut: Press {{{SHIFT}}} + {{{ENTER}}} to save.//
!end
!show
<html><form class="QAFlashMaker" style="display:inline;margin:0;padding:0;white-space:nowrap;"
action="#" onsubmit="function save(){
var when=new Date();
var title=when.formatString('$1');
if((temp=quest.value.replace(/^\s+|\s+$/g, ''))=='') return;
var text='Q: '+temp.replace(/\n+/g, '<BR />');
temp=ans.value.replace(/^\s+|\s+$/g, '');
text +='\nA: '+temp.replace(/^\s+|\s+$/g, '').replace(/\n+/g, '<BR />');
if(!store.tiddlerExists(title)){
var tagz=tags.value.readBracketedList();
store.saveTiddler(title,title,text,config.options.txtUserName,when,tagz);
story.displayTiddler(null,title);
}else{
store.getTiddler(title).text += '\n\n' + text;
store.dirty=true;
story.refreshTiddler(title,DEFAULT_VIEW_TEMPLATE,true);
}
autoSaveChanges();
quest.value=''; ans.value=''; quest.focus();
}; save()">
<input type="text" disabled value="Question:" style="width:45%" />
<input type="text" disabled value="Answer: " style="width:45%" />
<br />
<textarea name="quest" rows="5" cols="60" style="width:45%" onkeydown="
if(event.keyCode == 16) isShift =true;
if(isShift==true && event.keyCode == 13){ this.form.onsubmit(); return false;}
" onkeyup="isShift=false"></textarea>
<textarea name="ans" rows="5" cols="60" style="width:45%" onkeydown="
if(event.keyCode == 16) isShift =true;
if(isShift==true && event.keyCode == 13){ this.form.onsubmit(); return false;}
" onkeyup="isShift=false"></textarea>
<br />
<input type=hidden name="tags" value="$2" />
<input type=reset value="Clear" style="width:4em" onclick="this.form.quest.focus()" />
<input type=button value="Post" style="width:4em" onclick="this.form.onsubmit()" />
</form></html>
!end
%/<<tiddler {{'QAFlashMaker##'+('$1'=='$'+'1'?'info':'show')}} with: [[$1]] {{'$2'!='$'+'2'?'$2':''}}>>
<<myComment>>
----
~~:::::__Fri Jun 25 2010 20:57:55 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Same as QuickLog, added key binding(shift+enter) and auto focus.
----
~~:::::__Sat Jun 26 2010 14:15:54 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ added autosave check
/%
!info
Note: Changes are not saved.
{{{<<tiddler QuickLog with: Title_YYYY-0MM-0DD "tagname" "singleLine" "separator" "timeStamp">>}}}
{{{<<tiddler QuickLog with: Worklog_YYYY-0MM-0DD "worklog" "checked" "" "checked">>}}}
<<tiddler QuickLog with: Worklog_YYYY-0MM-0DD "worklog" "" "" "">>
//Shortcut: Press {{{SHIFT}}} + {{{ENTER}}} to save.//
!end
!show
<html>
<form class="QuickLog" name="$1" style="display:inline;margin:0;padding:0;white-space:nowrap;"
action="#" onsubmit="function save(){
var when=new Date();
var title=when.formatString('$1');
var tags='$2';
var who=config.options.txtUserName;
var text=txt.value.replace(/^\s+|\s+$/g, ''); if(text=='') return;
if(singleLine.checked) text=text.replace(/\s+/gm, ' ');
if(timeStamp.checked) text='~~:::::__'+when+'__:::::~~\n'+text;
if(!store.tiddlerExists(title)){
if(includeForm.checked)
text='<<tiddler QuickLog with: '+title+' '+tags+' \'$3\' \'$4\' \'$5\'>>\n!\n' + text;
store.saveTiddler(title,title,text,who,when,tags);
story.displayTiddler(null,title);
}else{
var tiddler = store.getTiddler(title);
if(separator.checked) tiddler.text += '\n----';
tiddler.text += '\n'+ text;
//store.saveTiddler(title,title,text,who,when,tags);
store.dirty=true;
story.refreshTiddler(title,DEFAULT_VIEW_TEMPLATE,true);
}
autoSaveChanges(); txt.value=''; txt.focus();
}; save();">
<input type=reset value="Clear" style="width:4em" onclick="this.form.txt.focus()" />
<input type=button value="Post" style="width:4em" onclick="this.form.onsubmit();" />
<span title="Single Line"><input type="checkbox" name="singleLine" $3>SL</input></span>
<span title="Separator"><input type="checkbox" name="separator" $4>HR</input></span>
<span title="Time Stamp"><input type="checkbox" name="timeStamp" $5>TS</input></span>
<span title="Include Form"><input type="checkbox" name="includeForm" $6>IF</input></span><br />
<textarea name="txt" rows="5" cols="60" style="width:90%" onkeydown="
if(event.keyCode == 16) isShift =true;
if(isShift==true && event.keyCode == 13){ this.form.onsubmit(); return false;}
" onkeyup="isShift=false"></textarea>
</form></html>
!end
%/<<tiddler {{'QuickLog##'+('$1'=='$'+'1'?'info':'show')}} with: [[$1]] {{'$2'!='$'+'2'?'$2':''}} {{'$3'!='$'+'3'?'$3':''}} {{'$4'!='$'+'4'?'$4':''}} {{'$5'!='$'+'5'?'$5':''}} {{'$6'!='$'+'6'?'$6':''}}>>
<<myComment>>
----
~~:::::__Fri Jun 25 2010 20:53:00 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ added tooltips, made checkboxes smaller, more screen realestate.
----
~~:::::__Fri Jun 25 2010 20:53:21 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Added keybinding for textarea. Couldn't override ctrl+enter, so I made it shift + enter instead.
----
~~:::::__Fri Jun 25 2010 20:54:33 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ set focus back to textarea each time you make a post. However this doesn't seem to work when embedded with the document. Maybe because of the refresh?
----
~~:::::__Sat Jun 26 2010 14:16:08 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ added autosave check
/%
!info
Example:
<<<
{{{<<tiddler QuickNote with: YYYY-0MM-0DD_0hh.0mm.0ss "quicknote journal">>}}}
<<tiddler QuickNote with: YYYY-0MM-0DD_0hh.0mm.0ss "quicknote journal">>
<<<
----
|Name|QuickNote|
|Source|http://www.TiddlyTools.com/#QuickNote|
|Version|1.0.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|transclusion|
|Description|create quick notes using timestamp as tiddler titles|
Usage:
<<<
in tiddler content:
{{{
<<tiddler QuickNote with: format "tag [[tag with spaces]] tag tag"...>>
}}}
in PageTemplate (added to story column):
{{{
<div id='displayArea'>
<div id='messageArea'></div>
<div macro='tiddler QuickNote with: format "tag [[tag with spaces]] tag tag"'></div>
<div id='tiddlerDisplay'></div>
</div>
}}}
where ''format'' specifies a TiddlyWiki date format string (e.g. """YYYY0MM0DD0hh0mm0ss""") that is used to generate a unique tiddler title for each new note that is created, by combining the TW username with a //timestamp// for the current time and ''tag tag tag'' are //optional// tag values to add to the newly created notes.
<<<
!end
!show
<html><nowiki><form class="quickNote" style="display:inline;margin:0;padding:0;white-space:nowrap;">
<input type=text id="quickNoteTitle" disabled value="" title="title for new tiddler" style="width:37%">
<input type=text name="tags" value="$2" title="tags for new tiddler" style="width:37%">
<input type=button value="Clear" style="width:6%" onclick="this.form.txt.value='';">
<input type=button value="Post" style="width:6%" onclick="
var who=config.options.txtUserName;
var when=new Date();
var title=when.formatString('$1');
// var title=prompt('The new tiddler title will be:\n\n',who+when.formatString('$1'));
// if (!title) return;
var msg=config.messages.overwriteWarning.format([title]);
if (store.tiddlerExists(title) && !confirm(msg)) return;
var text=this.form.txt.value;
if(text.replace(/^\s+|\s+$/g, '')=='') return;
var tags=this.form.tags.value.readBracketedList();
store.saveTiddler(title,title,text,who,when,tags,{});
story.displayTiddler(null,title);
this.form.txt.value='';
"><br><textarea name="txt" rows="5" cols="60" style="width:90%"></textarea>
</form></html><<tiddler {{
window.quickNoteTick=function() {
var e=document.getElementById('quickNoteTitle'); if (!e) return;
e.value='next title: '+new Date().formatString('$1');
window.setTimeout('window.quickNoteTick()',1000);
};
window.quickNoteTick()
'';}}>>
!end
%/<<tiddler {{'QuickNote##'+('$1'=='$'+'1'?'info':'show')}} with: [[$1]] {{'$2'!='$'+'2'?'$2':''}}>>
/***
|Name|QuoteOfTheDayPlugin|
|Source|http://www.TiddlyTools.com/#QuoteOfTheDayPlugin|
|Documentation|http://www.TiddlyTools.com/#QuoteOfTheDayPluginInfo|
|Version|1.4.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|Display a randomly selected "quote of the day" from a list defined in a separate tiddler|
!!!!!Revisions
<<<
2008.03.21 [1.4.1] in showNextItem(), corrected handling for random selection so that //initial// index value will randomized correctly instead of always showing first item, even when randomizing. Thanks to Riccardo Gherardi for finding this.
| Please see [[QuoteOfTheDayPluginInfo]] for previous revision details |
2005.10.21 [1.0.0] Initial Release. Based on a suggestion by M.Russula
<<<
!Example
//Click on quote://
:<<QOTD sample_quote norandom inline>>
!Usage
<<<
{{{<<QOTD tiddlername norandom noclick inline cookie:cookiename delay>>}}}
* ''tiddlername'' is the name of a tiddler containing your list of quotes, each separated by a horizontal line (use {{{----}}} on a line by itself).
* Each time the macro is rendered it will display a different quotation, selected at random from the specified tiddler. To display quotes in the sequence in which they occur in the tiddler, you can use the ''norandom'' keyword.
* When using ''norandom'', you can also specify an optional ''cookie:cookiename'' parameter which will be used to track the //index// of the next quote to be displayed, so that each subsequent rendering of the macro can continue the sequence of quotes as entered in the source tiddler, even in between browser sessions.
* By default, clicking on the rendered quote will select and display another random quote. Use the optional ''noclick'' keyword parameter to disable this "onClick" handling.
* By default, a clickable or timed quote will be displayed insider a 'slider' panel, so that standard TW animation effects will be used. However, slider panels are always rendered as "block-level" content, forcing a newline both before and after the slider panel. Use the ''inline'' keyword parameter to bypass this side-effect and display a clickable/timed quote without automatically adding surrounding linebreaks.
* The quote can also be refreshed automatically, by specifying a numeric ''delay'' parameter (in milliseconds) which enables a countdown timer. When the mouse is over the quote, the timer is automatically stopped. Moving the mouse away from the quote content restarts the timer.
<<<
!Code
***/
//{{{
version.extensions.QuoteOfTheDayPlugin= {major: 1, minor: 4, revision: 1, date: new Date(2008,3,21)};
config.macros.QOTD = {
clickTooltip: "click to view another item",
timerTooltip: "auto-timer stopped... 'mouseout' to restart timer",
timerClickTooltip: "auto-timer stopped... click to view another item, or 'mouseout' to restart timer",
handler:
function(place,macroName,params) {
var tid=params.shift(); // source tiddler containing HR-separated quotes
var p=params.shift();
var click=true; // allow click for next item
var inline=false; // wrap in slider for animation effect
var random=true; // pick an item at random (default for "quote of the day" usage)
var folder=false; // use local filesystem folder list
var cookie=""; // default to no cookie
var next=0; // default to first item (or random item)
while (p) {
if (p.toLowerCase()=="noclick") var click=false;
if (p.toLowerCase()=="inline") var inline=true;
if (p.toLowerCase()=="norandom") var random=false;
if (p.toLowerCase().substr(0,7)=="cookie:") var cookie='cookie_'+p.substr(7);
if (!isNaN(p)) var delay=p;
p=params.shift();
}
if ((click||delay) && !inline) {
var panel = createTiddlyElement(null,"div",null,"sliderPanel");
panel.style.display="none";
place.appendChild(panel);
var here=createTiddlyElement(panel,click?"a":"span",null,"QOTD");
}
else
var here=createTiddlyElement(place,click?"a":"span",null,"QOTD");
here.id=(new Date()).convertToYYYYMMDDHHMMSSMMM()+Math.random().toString(); // unique ID
// get items from tiddler or file list
var list=store.getTiddlerText(tid,"");
if (!list||!list.length) { // not a tiddler... maybe an image directory?
var list=this.getImageFileList(tid);
if (!list.length) { // maybe relative path... fixup and try again
var h=document.location.href;
var p=getLocalPath(decodeURIComponent(h.substr(0,h.lastIndexOf("/")+1)));
var list=this.getImageFileList(p+tid);
}
return false; // MOVED HERE
}
//if (!list||!list.length) return false; // no contents... nothing to display!
here.setAttribute("list",list);
if (delay) here.setAttribute("delay",delay);
here.setAttribute("random",random);
here.setAttribute("cookie",cookie);
if (click) {
here.title=this.clickTooltip
if (!inline) here.style.display="block";
here.setAttribute("href","javascript:;");
here.onclick=function(event)
{ config.macros.QOTD.showNextItem(this); }
}
if (store.tiddlerExists(cookie)){
t=store.getTiddler(cookie);
next=parseInt(t.text);
}
here.setAttribute("nextItem",next);
config.macros.QOTD.showNextItem(here);
if (delay) {
here.title=click?this.timerClickTooltip:this.timerTooltip
here.onmouseover=function(event)
{ clearTimeout(this.ticker); };
here.onmouseout=function(event)
{ this.ticker=setTimeout("config.macros.QOTD.tick('"+this.id+"')",this.getAttribute("delay")); };
here.ticker=setTimeout("config.macros.QOTD.tick('"+here.id+"')",delay);
}
},
tick: function(id) {
var here=document.getElementById(id); if (!here) return;
config.macros.QOTD.showNextItem(here);
here.ticker=setTimeout("config.macros.QOTD.tick('"+id+"')",here.getAttribute("delay"));
},
showNextItem:
function (here) {
// hide containing slider panel (if any)
var p=here.parentNode;
if (p.className=="sliderPanel") p.style.display = "none"
// get a new quote
var index=here.getAttribute("nextItem");
var items=here.getAttribute("list").split(/\n-{4,}\n/img);
if (index<0||index>=items.length) index=0;
if (here.getAttribute("random")=="true") index=Math.floor(Math.random()*items.length);
var txt=items[index];
// fixes recursion problem if macro is embedded into quote file.
if(/<<QOTD .+>>/gm.test(txt)){
txt=items[index = (++index>=items.length) ? 0 : index].replace(/<<QOTD .+>>/gm,'@~ERROR-index='+index+'@');
//if by itself and no other text or two qotd macros side by side, it freezes, so I used replace here.
}else if(txt=='%/') txt=items[index = (++index>=items.length) ? 0 : index]
// re-render quote display element, and advance index counter
removeChildren(here); wikify(txt,here);
here.setAttribute("nextItem",++index);
var cookie=here.getAttribute("cookie");
if (cookie.length) {
store.saveTiddler(cookie,cookie,index.toString(),config.options.txtUserName,(new Date()),'cookie excludeLists',{});
}
// redisplay slider panel (if any)
if (p.className=="sliderPanel") {
if(anim && config.options.chkAnimate)
anim.startAnimating(new Slider(p,true,false,"none"));
else p.style.display="block";
}
},
getImageFileList: function(cwd) { // returns HR-separated list of image files
function isImage(fn) {
var ext=fn.substr(fn.length-3,3).toLowerCase();
return ext=="jpg"||ext=="gif"||ext=="png";
}
var files=[];
if (config.browser.isIE) {
cwd=cwd.replace(/\//g,"\\");
// IE uses ActiveX to read filesystem info
var fso = new ActiveXObject("Scripting.FileSystemObject");
if(!fso.FolderExists(cwd)) return [];
var dir=fso.GetFolder(cwd);
for(var f=new Enumerator(dir.Files); !f.atEnd(); f.moveNext())
if (isImage(f.item().path)) files.push("[img[%0]]".format(["file:///"+f.item().path.replace(/\\/g,"/")]));
} else {
// FireFox (mozilla) uses "components" to read filesystem info
// get security access
if(!window.Components) return;
try { netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect"); }
catch(e) { alert(e.description?e.description:e.toString()); return []; }
// open/validate directory
var file=Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
try { file.initWithPath(cwd); } catch(e) { return []; }
if (!file.exists() || !file.isDirectory()) { return []; }
var folder=file.directoryEntries;
while (folder.hasMoreElements()) {
var f=folder.getNext().QueryInterface(Components.interfaces.nsILocalFile);
if (f instanceof Components.interfaces.nsILocalFile)
if (isImage(f.path)) files.push("[img[%0]]".format(["file:///"+f.path.replace(/\\/g,"/")]));
}
}
return files.join("\n----\n");
}
}
//}}}
<<myComment>>
----
~~:::::__Fri Jun 25 2010 21:40:38 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Change to: use tiddler to keep count instead of using cookies.
{{{
if (cookie.length) {
store.saveTiddler(cookie,cookie,index.toString(),config.options.txtUserName,(new Date()),'cookie excludeLists',{});
}
}}}
----
~~:::::__Fri Jun 25 2010 21:42:15 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ If macro is embeded into quote file, it will call itself recursively and freeze the browser.
{{{if(/<<QOTD .+>>/gm.test(txt)) txt=items[++index>=items.length?0:index];}}}
this fixes if random and embedded qotd macro tag
----
~~:::::__Fri Jun 25 2010 21:42:37 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Code change: use regex instead of string matching.
{{{var items=here.getAttribute("list").split(/\n-{4,}\n/img);}}}
----
~~:::::__Fri Jun 25 2010 21:46:11 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ If there are more than one <<QOTD>> tags embedded into the same quote file, it seems to freeze the browser. This is a temp workaround. I really like to line them up against each other.
{{{
// fixes recursion problem if macro is embedded into quote file.
if(/<<QOTD .+>>/gm.test(txt)){
txt=items[index = (++index>=items.length) ? 0 : index].replace(/<<QOTD .+>>/gm,'@~ERROR-index='+index+'@');
//if by itself and no other text or two qotd macros side by side, it freezes, so I used replace here.
}
}}}
----
~~:::::__Sun Jun 27 2010 22:00:44 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ added: {{{else if(txt=='%/') txt=items[index = (++index>=items.length) ? 0 : index]}}} so /%...%/ comment tags could be skipped, thus hidding the quotes in an embedded document.
<<rssFeedUpdateAllButton>>
<<rssReader asHtml http://tiddlywiki.bidix.info/index.xml 1>>
<<rssReader asHtml http://feeds.feedburner.com/brainyquote/QUOTEBR 1>>
<<rssReader asHtml http://www.thefreedictionary.com/_/WoD/rss.aspx 1 >>
<<rssReader asHtml http://feeds.urbandictionary.com/UrbanWordOfTheDay 1 >>
<<rssReader asHtml http://feeds.dilbert.com/DilbertDailyStrip 1 >>
<<rssReader asHtml http://rss.news.yahoo.com/rss/sports 5>>
/***
|''Name:''|RSSReaderPlugin|
|''Description:''|This plugin provides a RSSReader for TiddlyWiki|
|''Version:''|1.1.2|
|''Date:''|2008-09-02|
|''Source:''|http://tiddlywiki.bidix.info/#RSSReaderPlugin|
|''Documentation:''|http://tiddlywiki.bidix.info/#RSSReaderPluginDoc|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''Credit:''|BramChen for RssNewsMacro|
|''[[License]]:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
|''OptionalRequires:''|http://www.tiddlytools.com/#NestedSlidersPlugin|
!Examples
{{{<<rssFeedUpdateAllButton>>}}}
<<rssFeedUpdateAllButton>>
'''{{{<<rssReader asDesc|asHtml rssUrl [limit] ['filtering string']>>}}}'''
{{{<<rssReader asHtml http://www.thefreedictionary.com/_/WoD/rss.aspx>>}}}
{{{<<rssReader asHtml http://feeds.urbandictionary.com/UrbanWordOfTheDay 1>>}}}
!My Changes:
*added a limit so that it just shows n number of feeds instead of the entire list each time.
*added a universal clear cache button function.
- - code hidden - -
***/
//{{{
version.extensions.RSSReaderPlugin = {
major: 1, minor: 1, revision: 2,
date: new Date("2008-09-02"),
source: "http://TiddlyWiki.bidix.info/#RSSReaderPlugin",
author: "BidiX",
coreVersion: '2.2.0'
};
config.macros.rssReader = {
dateFormat: "DDD, DD MMM YYYY",
itemStyle: "display: block;border: 1px solid black;padding: 5px;margin: 5px;", //useed '@@'+itemStyle+itemText+'@@'
msg:{
permissionDenied: "Permission to read preferences was denied.",
noRSSFeed: "No RSS Feed at this address %0",
urlNotAccessible: " Access to %0 is not allowed"
},
cache: [], // url => XMLHttpRequest.responseXML
desc: "noDesc",
limit: null,
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var desc = params[0];
var feedURL = params[1];
var limit = params[2];
var toFilter = (params[3] ? true : false);
var filterString = (toFilter?(params[3].substr(0,1) == ' '? tiddler.title:params[3]):'');
var place = createTiddlyElement(place, "div", "RSSReader");
//wikify("^^<<rssFeedUpdate "+feedURL+" [[" + tiddler.title + "]]>>^^\n",place);
if (this.cache[feedURL]) {
this.displayRssFeed(this.cache[feedURL], place, feedURL, desc, limit, toFilter, filterString);
}
else {
var r = loadRemoteFile(feedURL,config.macros.rssReader.processResponse, [place, desc, limit, toFilter, filterString]);
if (typeof r == "string")
displayMessage(r);
}
},
// callback for loadRemoteFile
// params : [place, desc, toFilter, filterString]
processResponse: function(status, params, responseText, url, xhr) { // feedURL, place, desc, toFilter, filterString) {
if (window.netscape){
try {
if (document.location.protocol.indexOf("http") == -1) {
netscape.security.PrivilegeManager.enablePrivilege("UniversalBrowserRead");
}
}
catch (e) { displayMessage(e.description?e.description:e.toString()); }
}
if (xhr.status == 404)
{
displayMessage(config.macros.rssReader.noRSSFeed.format([url]));
return;
}
if (!status)
{
displayMessage(config.macros.rssReader.noRSSFeed.format([url]));
return;
}
if (xhr.responseXML) {
// response is interpreted as XML
config.macros.rssReader.cache[url] = xhr.responseXML;
config.macros.rssReader.displayRssFeed(xhr.responseXML, params[0], url, params[1], params[2], params[3], params[4]);
}
else {
if (responseText.substr(0,5) == "<?xml") {
// response exists but not return as XML -> try to parse it
var dom = (new DOMParser()).parseFromString(responseText, "text/xml");
if (dom) {
// parsing successful so use it
config.macros.rssReader.cache[url] = dom;
config.macros.rssReader.displayRssFeed(dom, params[0], url, params[1], params[2], params[3], params[4]);
return;
}
}
// no XML display as html
wikify("<html>" + responseText + "</html>", params[0]);
displayMessage(config.macros.rssReader.msg.noRSSFeed.format([url]));
}
},
// explore down the DOM tree
displayRssFeed: function(xml, place, feedURL, desc, limit, toFilter, filterString){
// Channel
var chanelNode = xml.getElementsByTagName('channel').item(0);
var chanelTitleElement = (chanelNode ? chanelNode.getElementsByTagName('title').item(0) : null);
var chanelTitle = "";
if ((chanelTitleElement) && (chanelTitleElement.firstChild))
chanelTitle = chanelTitleElement.firstChild.nodeValue;
var chanelLinkElement = (chanelNode ? chanelNode.getElementsByTagName('link').item(0) : null);
var chanelLink = "";
if (chanelLinkElement)
chanelLink = chanelLinkElement.firstChild.nodeValue;
var titleTxt = "!![["+chanelTitle+"|"+chanelLink+"]]\n";
var title = createTiddlyElement(place,"div",null,"ChanelTitle",null);
wikify(titleTxt,title);
// ItemList
var itemList = xml.getElementsByTagName('item');
var article = createTiddlyElement(place,"ul",null,null,null);
var lastDate;
var re;
if(!limit) limit = itemList.length;
else limit = Math.min(itemList.length,limit);
if (toFilter)
re = new RegExp(filterString.escapeRegExp());
for (var i=0; i<limit; i++){
var titleElm = itemList[i].getElementsByTagName('title').item(0);
var titleText = (titleElm ? titleElm.firstChild.nodeValue : '');
if (toFilter && ! titleText.match(re)) {
continue;
}
var descText = '';
descElem = itemList[i].getElementsByTagName('description').item(0);
if (descElem){
try{
for (var ii=0; ii<descElem.childNodes.length; ii++) {
descText += descElem.childNodes[ii].nodeValue;
}
}
catch(e){}
descText = descText.replace(/<br \/>/g,'\n');
if (desc == "asHtml")
descText = "<html>"+descText+"</html>";
}
var linkElm = itemList[i].getElementsByTagName("link").item(0);
var linkURL = linkElm.firstChild.nodeValue;
var pubElm = itemList[i].getElementsByTagName('pubDate').item(0);
var pubDate;
if (!pubElm) {
pubElm = itemList[i].getElementsByTagName('date').item(0); // for del.icio.us
if (pubElm) {
pubDate = pubElm.firstChild.nodeValue;
pubDate = this.formatDateString(this.dateFormat, pubDate);
}
else {
pubDate = '0';
}
}
else {
pubDate = (pubElm ? pubElm.firstChild.nodeValue : 0);
pubDate = this.formatDate(this.dateFormat, pubDate);
}
titleText = titleText.replace(/\[|\]/g,'');
var rssText = '*'+'[[' + titleText + '|' + linkURL + ']]' + '' ;
if ((desc != "noDesc") && descText){
rssText = rssText.replace(/\n/g,' ');
descText = '@@'+this.itemStyle+descText + '@@\n';
if (version.extensions.nestedSliders){
descText = '+++[...]' + descText + '===';
}
rssText = rssText + descText;
}
var story;
if ((lastDate != pubDate) && ( pubDate != '0')) {
story = createTiddlyElement(article,"li",null,"RSSItem",pubDate);
lastDate = pubDate;
}
else {
lastDate = pubDate;
}
story = createTiddlyElement(article,"div",null,"RSSItem",null);
wikify(rssText,story);
}
},
formatDate: function(template, date){
var dateString = new Date(date);
// template = template.replace(/hh|mm|ss/g,'');
return dateString.formatString(template);
},
formatDateString: function(template, date){
var dateString = new Date(date.substr(0,4), date.substr(5,2) - 1, date.substr(8,2));
return dateString.formatString(template);
}
};
config.macros.rssFeedUpdate = {
label: "Update",
prompt: "Clear the cache and redisplay this RssFeed",
handler: function(place,macroName,params) {
var feedURL = params[0];
var tiddlerTitle = params[1];
createTiddlyButton(place, this.label, this.prompt,
function () {
if (config.macros.rssReader.cache[feedURL]) {
config.macros.rssReader.cache[feedURL] = null;
}
story.refreshTiddler(tiddlerTitle,null, true);
return false;});
}
};
config.macros.rssFeedUpdateAllButton = {
label: "Update Feeds",
prompt: "Clear the cache and redisplay this RssFeed",
handler: function(place) {
createTiddlyButton(place, this.label, this.prompt,
function () {
config.macros.rssReader.cache=[];
story.refreshAllTiddlers();
return false;
}
);
}
};
//}}}
//%/
/***
|''Name:''|ReadOnlyPlugin|
|''Description:''|Makes tiddlers tagged readOnly read only.|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#ReadOnlyPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Beta|
|''Date:''|June 28, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Makes tiddlers tagged readOnly uneditable.
!!Usage
#Import
#Save & Reload
#Add "readOnlyTiddler" to [[ToolbarCommands]]
**Click "readOnly" command to tag it readOnly, CTRL+click to untag it.
!!Configuration
<<option chkHideReadOnlyButton>> Hide readOnly command in read only tiddlers?
!!Code
***/
//{{{
if(!version.extensions.ReadOnlyPlugin) {
version.extensions.ReadOnlyPlugin= {installed:true};
if(!config.options.chkHideReadOnlyButton)
config.options.chkHideReadOnlyButton=true;
config.commands.readOnlyTiddler = {
text: "read only",
tooltip: "Make this tiddler read only.",
warning: 'Make this "Read Only", are you sure?',
handler: function(event,src,title) {
if(!event.ctrlKey && confirm(this.warning)){
store.setTiddlerTag(title,1,"readOnly");
}else if(event.ctrlKey){
store.setTiddlerTag(title,0,"readOnly");
}
return false;
},
};
if(!window.cooltool) window.cooltool={};
if(!cooltool.readOnly) cooltool.readOnly={};
//}}}
/***
!!!!Hijacked getTemplateForTiddler
***/
//{{{
cooltool.readOnly.ori_getTemplate = Story.prototype.getTemplateForTiddler;
Story.prototype.getTemplateForTiddler=function(title,template,tiddler){
var t=cooltool.readOnly.ori_getTemplate(title,template,tiddler);
if(tiddler.tags.contains("readOnly")){
t=t.replace(/(edit|delete)Tiddler/g,"");
if(config.options.chkHideReadOnlyButton)
t=t.replace(/readOnlyTiddler/g,"");
}
return t;
};
} //# end of 'install only once'
//}}}
<<myComment>>
----
~~:::::__Mon Jun 28 2010 22:25:36 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^
Two possible ways of implementing this:
*config.commands.editTiddler.handler
*Story.prototype.getTemplateForTiddler
----
~~:::::__Sun Jul 04 2010 00:24:08 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ This way works too, but you can still go into view mode.
//{{{
ori_getTemplate = Story.prototype.getTemplateForTiddler;
Story.prototype.getTemplateForTiddler=function(title,template,tiddler){
var t=ori_getTemplate(title,template,tiddler);
if(tiddler.tags.contains("readOnly")){
readOnly= true;
}
else readOnly=false;
return t;
};
//}}}
/***
|Name|RearrangeTiddlersPlugin|
|Source|http://www.TiddlyTools.com/#RearrangeTiddlersPlugin|
|Version|2.0.0|
|Author|Eric Shulman|
|OriginalAuthor|Joe Raii|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|drag tiddlers by title to re-order story column display|
adapted from: http://www.cs.utexas.edu/~joeraii/dragn/#Draggable
changes by ELS:
* hijack refreshTiddler() instead of overridding createTiddler()
* find title element by className instead of elementID
* set cursor style via code instead of stylesheet
* set tooltip help text
* set tiddler "position:relative" when starting drag event, restore saved value when drag ends
* update 2006.08.07: use getElementsByTagName("*") to find title element, even when it is 'buried' deep in tiddler DOM elements (due to custom template usage)
* update 2007.03.01: use apply() to invoke hijacked core function
* update 2008.01.13: only hijack core function once. (allows for dynamic loading of plugin via bookmarklet)
* update 2008.10.19: added onclick popup menu with 'move to top' and 'move to bottom' commands
***/
///%
if (Story.prototype.rearrangeTiddlersHijack_refreshTiddler===undefined) {
Story.prototype.rearrangeTiddlersHijack_refreshTiddler = Story.prototype.refreshTiddler;
Story.prototype.refreshTiddler = function(title,template)
{
this.rearrangeTiddlersHijack_refreshTiddler.apply(this,arguments);
var theTiddler = document.getElementById(this.idPrefix + title); if (!theTiddler) return;
var theHandle;
var children=theTiddler.getElementsByTagName("*");
for (var i=0; i<children.length; i++) if (hasClass(children[i],"title")) { theHandle=children[i]; break; }
if (!theHandle) return theTiddler;
Drag.init(theHandle, theTiddler, 0, 0, null, null);
theHandle.style.cursor="move";
theHandle.title="drag title to re-arrange tiddlers, click for more options..."
theTiddler.onDrag = function(x,y,myElem) {
if (this.style.position!="relative")
{ this.savedstyle=this.style.position; this.style.position="relative"; }
y = myElem.offsetTop;
var next = myElem.nextSibling;
var prev = myElem.previousSibling;
if (next && y + myElem.offsetHeight > next.offsetTop + next.offsetHeight/2) {
myElem.parentNode.removeChild(myElem);
next.parentNode.insertBefore(myElem, next.nextSibling);//elems[pos+1]);
myElem.style["top"] = -next.offsetHeight/2+"px";
}
if (prev && y < prev.offsetTop + prev.offsetHeight/2) {
myElem.parentNode.removeChild(myElem);
prev.parentNode.insertBefore(myElem, prev);
myElem.style["top"] = prev.offsetHeight/2+"px";
}
};
theTiddler.onDragEnd = function(x,y,myElem) {
myElem.style["top"] = "0px";
if (this.savedstyle!=undefined)
this.style.position=this.savedstyle;
};
theHandle.onclick=function(ev) {
ev=ev||window.event;
var p=Popup.create(this); if (!p) return;
// REQUIRES "Collapse Plugins"
// config.commands.collapseOthers.handler(ev,this,title);
config.commands.toggleTiddler.handler(ev,this,title);
// DISABLED
/**************************************************************************
var b=createTiddlyButton(createTiddlyElement(p,"li"),
"\u25B2 move to top of column ","move this tiddler to the top of the story column",
function() {
var t=story.getTiddler(this.getAttribute("tid"));
t.parentNode.insertBefore(t,t.parentNode.firstChild); // move to top of column
window.scrollTo(0,ensureVisible(t));
return false;
});
b.setAttribute("tid",title);
var b=createTiddlyButton(createTiddlyElement(p,"li"),
"\u25BC move to bottom of column ","move this tiddler to the bottom of the story column",
function() {
var t=story.getTiddler(this.getAttribute("tid"));
t.parentNode.insertBefore(t,null); // move to bottom of column
window.scrollTo(0,ensureVisible(t));
return false;
});
b.setAttribute("tid",title);
Popup.show();
ev.cancelBubble=true; if (ev.stopPropagation) ev.stopPropagation(); return(false);
****************************************************************************/
};
return theTiddler;
}
}
/**************************************************
* dom-drag.js
* 09.25.2001
* www.youngpup.net
**************************************************
* 10.28.2001 - fixed minor bug where events
* sometimes fired off the handle, not the root.
**************************************************/
var Drag = {
obj:null,
init:
function(o, oRoot, minX, maxX, minY, maxY) {
o.onmousedown = Drag.start;
o.root = oRoot && oRoot != null ? oRoot : o ;
if (isNaN(parseInt(o.root.style.left))) o.root.style.left="0px";
if (isNaN(parseInt(o.root.style.top))) o.root.style.top="0px";
o.minX = typeof minX != 'undefined' ? minX : null;
o.minY = typeof minY != 'undefined' ? minY : null;
o.maxX = typeof maxX != 'undefined' ? maxX : null;
o.maxY = typeof maxY != 'undefined' ? maxY : null;
o.root.onDragStart = new Function();
o.root.onDragEnd = new Function();
o.root.onDrag = new Function();
},
start:
function(e) {
var o = Drag.obj = this;
e = Drag.fixE(e);
var y = parseInt(o.root.style.top);
var x = parseInt(o.root.style.left);
o.root.onDragStart(x, y, Drag.obj.root);
o.lastMouseX = e.clientX;
o.lastMouseY = e.clientY;
if (o.minX != null) o.minMouseX = e.clientX - x + o.minX;
if (o.maxX != null) o.maxMouseX = o.minMouseX + o.maxX - o.minX;
if (o.minY != null) o.minMouseY = e.clientY - y + o.minY;
if (o.maxY != null) o.maxMouseY = o.minMouseY + o.maxY - o.minY;
document.onmousemove = Drag.drag;
document.onmouseup = Drag.end;
Drag.obj.root.style["z-index"] = "10";
return false;
},
drag:
function(e) {
e = Drag.fixE(e);
var o = Drag.obj;
var ey = e.clientY;
var ex = e.clientX;
var y = parseInt(o.root.style.top);
var x = parseInt(o.root.style.left);
var nx, ny;
if (o.minX != null) ex = Math.max(ex, o.minMouseX);
if (o.maxX != null) ex = Math.min(ex, o.maxMouseX);
if (o.minY != null) ey = Math.max(ey, o.minMouseY);
if (o.maxY != null) ey = Math.min(ey, o.maxMouseY);
nx = x + (ex - o.lastMouseX);
ny = y + (ey - o.lastMouseY);
Drag.obj.root.style["left"] = nx + "px";
Drag.obj.root.style["top"] = ny + "px";
Drag.obj.lastMouseX = ex;
Drag.obj.lastMouseY = ey;
Drag.obj.root.onDrag(nx, ny, Drag.obj.root);
return false;
},
end:
function() {
document.onmousemove = null;
document.onmouseup = null;
Drag.obj.root.style["z-index"] = "0";
Drag.obj.root.onDragEnd(parseInt(Drag.obj.root.style["left"]), parseInt(Drag.obj.root.style["top"]), Drag.obj.root);
Drag.obj = null;
},
fixE:
function(e) {
if (typeof e == 'undefined') e = window.event;
if (typeof e.layerX == 'undefined') e.layerX = e.offsetX;
if (typeof e.layerY == 'undefined') e.layerY = e.offsetY;
return e;
}
};
//%/
/***
|''Name:''|RenameTiddlerPlugin|
|''Description:''|Renames tiddlers quickly|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#RenameTiddlerPlugin|
|''Dependencies:''||
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|July 6, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Adds a button on the toolbar command to rename tiddlers quickly.
!!Usage
#Import
#Save & Reload
#Add {{{renameTiddler}}} to [[ToolbarCommands]] in the ~ViewToolbar slice.
!!Code
***/
//{{{
if(!version.extensions.RenameTiddlerPlugin) {
version.extensions.RenameTiddlerPlugin={installed:true};
config.commands.renameTiddler= {
text: "rename",
tooltip: "Rename Tiddler",
readOnlyText: "",
readOnlyTooltip: "",
handler: function(event,src,title) {
var tiddler=store.getTiddler(title);
var ans=prompt("Enter new title: ",title);
story.closeTiddler(title,false,false);
store.deleteTiddler(title);
tiddler.set(ans);
//store.saveTiddler(title,ans,tiddler.text,who,date,tags,this.tiddler.fields);
store.addTiddler(tiddler); store.notify(title,true); store.notify(ans,true);
store.dirty=true; store.setDirty(title,true); autoSaveChanges();
story.displayTiddler(null,ans);
return false;
},
};
} //# end of 'install only once'
//}}}
/***
|''Name:''|SQLQueryPlugin|
|''Version:''|0.1|
|''Source''|http://jackparke.googlepages.com/jtw.html#SQLQueryPlugin ([[del.icio.us|http://del.icio.us/post?url=http://jackparke.googlepages.com/jtw.html%23SQLQueryPlugin]])|
|''Author:''|[[Jack]]|
!Description
Query a SQL database (defined in [[SQLConfig]]) and display results in a tiddler. See [[SQLExamples]].
See http://www.connectionstrings.com for connection strings examples.
!Usage
{{{<<SQLQuery sql:"SELECT * FROM Products">>}}}
!Example
{{{<<SQLQuery sql:"SELECT TOP 10 ProductID, ProductName FROM Products">>}}}
<<SQLQuery sql:"SELECT TOP 10 ProductID, ProductName FROM Products">>
{{{<<SQLQuery sql:"SELECT TOP 10 au_id, au_lname, au_fname FROM Authors" connection:pubs>>}}}
<<SQLQuery sql:"SELECT TOP 10 au_id, au_lname, au_fname FROM Authors" connection:pubs>>
!Advanced Usage
{{{<<SQLQuery sql:"SELECT * FROM Products" connection:pubs rowstart:"*" colsep:"," rowend:{{\n}} headerstart:!>>}}}
!Configuration
Define all database connection strings (ADO) in the [[SQLConfig]] tiddler.
Example:
{{{
Northwind: DRIVER={SQL Server};SERVER=(local);DATABASE=Northwind;
pubs: DRIVER={SQL Server};SERVER=(local);DATABASE=pubs;
CompanyContacts: DRIVER={SQL Server};SERVER=MyCompanyServer;DATABASE=Contacts;UID=sa;pwd=admin;
}}}
!Code
***/
//{{{
version.extensions.SQLQuery= {major: 0, minor: 1, revision: 0, date: new Date("Aug 23, 2007")};
config.macros.SQLQuery= {};
//config.shadowTiddlers.SQLConfig = 'Connection1: DRIVER={SQL Server};SERVER=(local);DATABASE=Northwind;';
config.macros.SQLQuery.handler = function(place,macroName,params,wikifier,paramString,tiddler) {
var parameters = paramString.parseParams('name',null,true);
var pSQL = parameters[0]['sql']?parameters[0]['sql'][0]:-1;
if (!pSQL) return false;
var Connection = parameters[0]['connection']?parameters[0]['connection'][0]:'Connection1';
var SQLConnection = store.getTiddlerText('SQLConfig::' + Connection)
if (!SQLConnection) return wikify('Please configure this connection \'' + Connection + '\' in [[SQLConfig]]!', place, null, tiddler);
var RowStart = parameters[0]['rowstart']?parameters[0]['rowstart'][0]:'|';
var ColSep = parameters[0]['colsep']?parameters[0]['colsep'][0]:'|';
var RowEnd = parameters[0]['rowend']?parameters[0]['rowend'][0]:'|\n';
var HeaderStart = parameters[0]['headerstart']?parameters[0]['headerstart'][0]:'!~';
try {
var strResult = sql_DBQuery(SQLConnection, pSQL, RowStart, ColSep, RowEnd, HeaderStart, 'No results')
wikify(strResult,place, null, tiddler)
} catch (err) {
wikify('Error ' + err.message,place, null, tiddler)
}
}
function sql_DBQuery(ConnStr, SQL, RowStart, ColSep, RowEnd, HeaderStart, NoData) {
var Conn = new ActiveXObject('ADODB.Connection');
Conn.open(ConnStr);
var RS = Conn.execute(SQL);
var strOut='';
if (!RS.eof) {
strOut += RowStart;
for (var i=0; i < RS.Fields.Count; i++) {
strOut += HeaderStart + RS.Fields(i).name.toString() + (i<RS.Fields.Count-1?ColSep:'');
}
strOut += RowEnd;
while (!RS.eof) {
strOut += RowStart;
for (var i=0; i < RS.Fields.Count; i++) {
strOut += RS.Fields(i).Value.toString() + (i<RS.Fields.Count-1?ColSep:'');
}
strOut += RowEnd;
RS.MoveNext
}
} else {
strOut = NoData;
}
return strOut;
RS.close()
Conn.close()
}
//}}}
!Fold Headings Plugin:
!!!Word Count
[img[wordCount.png]]
!!!Read Only Plugin
[img[readOnly.png]]
!!!ClearChangeCountPlugin
[img[clearChangeCount.png]]
!!!ExportCommandPlugin
[img[exportCommandPlugin.png]]
!!!AttachFilePlugin - Hidden Data section
[img[EmbeddedHiddenData.png]]
!!!sectio opened, with option to close
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA<<foldHeadings opened>>
!!!section folded, with option to open
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA
AAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAAAAAAA AAAAAAAAAAA AAAAAAA AAAAAAA
<<foldHeadings closed>>
!SyntaxHighlighter
!!!Java
<code java>
public void printHello(){
System.out.println("Hello World");
}
</code>
!!!Python
<code python>
print "Hello, World!"
</code>
!Calendar
<<calendar thismonth>>
!AnnotationPlugin
Mouse over, the text below:
* ((banana(the best fruit in the world)))
* ((banana(^ the best fruit in the world)))
!FootnotesPlugin
''Try clicking on the red numbers, in the paragraphs below, to see the footnotes.
Lorem ipsum dolor sit amet, consectetuer adipiscing elit```This is my first footnote```. Duis eleifend. Phasellus id orci. Suspendisse quis elit pharetra arcu fringilla vulputate. Nullam et orci. In vel dolor quis eros euismod vehicula. Ut elementum egestas nibh. Sed at urna non lectus```You can have as many footnotes as you like``` accuconvallis blandit```Clicking on a footnote link, takes you to the footnote```.
Aliquam erat volutpat. Nam congue. eget sem sollicitudin auctor```Footnotes are numbered automatically```. Donec hendrerit, lorem id tincidunt bibendum, dolor dui dignissim velit, eu aliquet dolor sapien tincidunt nunc. Duis condimentum leo laoreet nibh. Proin in lacus quis ante lacinia vestibulum. Mauris turpis. Donec elementum lacinia turpis. Donec enim diam, feugiat id, feugiat gravida, mollis non, magna```Each footnote, has a back button, to take you to where you came from```.
!ExternalTiddlersPlugin
:{{{<<tiddler ' fileTiddlyWiki.html#"My Tiddly Title" ' >>}}}
/***
|''Name:''|SessionManagerPlugin|
|''Description:''|Manage Your Sessions|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#SessionManagerPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|June 29, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Manages your sessions.
*Store your last opened tiddlers in a cookie and reopen them on restart.
*Save and reload any session manually.
!!Usage
#Import
#Save & Reload
<<<
{{{<<session>>}}} OR {{{<<session tiddlerName sectionTitle>>}}}
__example:__
{{{<<session mySessions memo>>}}} This will look for !memo in the mySessions tiddler.
<<session>>
<<<
!!Configuration
<<option chkDoNotAutoLoadSession>> Don't Auto load last session.
!!To do
Make gui front end.
prevent overwriting tiddlers not tagged as session
!!Code
***/
//{{{
if(!version.extensions.SessionManagerPlugin) {
version.extensions.SessionManagerPlugin= {installed:true};
config.macros.session= {
template: '',
handler: function(place,macroName,params,wikifier,paramString,tiddler){
var tid=store.getTiddler(params[0]);
var section=params[1];
//LOAD
createTiddlyButton(place,"Load","",function(){
if(!tid&&!section) { alert("params required"); return;}
cooltool.session.loadSession(tid,section,tiddler.title)});
//SAVE
createTiddlyButton(place,"Save","",function(){
if(!tid&&!section){ alert("params required"); return;}
cooltool.session.saveSession(tid,section)});
//LIST
createTiddlyButton(place,"List","",function(){
if(!tid&&!section){ alert("params required"); return;}
alert(cooltool.session.listSession(tid).join("\n"))});
//wikify(template,'');
},
};
//----------------------------
if(!config.options.chkDoNotAutoLoadSession) config.options.chkDoNotAutoLoadSession=false;
if(!window.cooltool) window.cooltool={};
cooltool.session={
sessionId:('TWS'+escape(document.title).replace(/[^a-z]/ig,'')),
sectionFormat: "\n!%0\n%1",
listSession: function(tiddler){
var list = []; var v;
while(v=/^!.+?\n/gm.exec(tiddler.text)){
list.push(v.toString().replace(/^!+/,''));
}
return list;
},
loadSession: function(tiddler,section,title){
links=store.getTiddlerText(tiddler.title+'##'+section,null);
story.closeAllTiddlers(title); // title of tid to keep open
cooltool.session.displayTiddlers(links);
return true;
},
saveSession: function(tiddler,section){
if(store.getTiddlerText(tiddler.title+'##'+section,null)){
if(!confirm(section+" already exists, overwrite?")) return;
arr=eval("tiddler.text.split(/^!+"+section+"\\n.*/m)");
tiddler.text=arr.join("").replace(/\s+$/,'');
}
value=cooltool.session.getDisplayedTiddlers();
tiddler.text+=this.sectionFormat.format([section,value]);
story.refreshTiddler(tiddler.title,null,true);
store.setDirty(true);
return true;
},
getDisplayedTiddlers: function(){
var links=[];
story.forEachTiddler(function(title,element) {
if(title !="PluginManager")
links.push(String.encodeTiddlyLink(title));
});
return links.join(" ");
},
displayTiddlers: function(str){
var links=str.readBracketedList();
story.displayTiddlers(null,links,null,false,false);
},
};
if(!cooltool.cookie) cooltool.cookie = {
set: function(sKey,sValue,date){
if(!date){
date=new Date();
date.setFullYear(date.getFullYear()+2);
}
document.cookie=sKey+"="+sValue+";expires="+date.toGMTString();
return true;
},
get: function(sKey){
var cookie=document.cookie.split(";");
var sValue=eval("/"+sKey+"=.*?;/.exec(document.cookie)");
sValue=sValue.toString().replace(/^.*?=(.*);/,"$1");
return sValue;
},
};
//--------------------------
// HIJACKED FUNCTIONS
//--------------------------
cooltool.session.oldConfirmExit = confirmExit;
confirmExit = function(){
var links=cooltool.session.getDisplayedTiddlers();
cooltool.cookie.set(cooltool.session.sessionId,links);
return cooltool.session.oldConfirmExit();
};
cooltool.session.oldRestart = restart;
restart = function(){
cooltool.session.oldRestart();
if(story.isEmpty() && !config.options.chkDoNotAutoLoadSession){
var links=cooltool.cookie.get(cooltool.session.sessionId);
cooltool.session.displayTiddlers(links);
}
};
} //# end of 'install only once'
//}}}
<<myComment>>
----
~~:::::__Fri Jul 02 2010 15:05:05 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ add safty so if user holds down shift key, session would not load or be saved.
<<saveChanges>><<closeAll>><<collapseAll>><<expandAll>><<toggleAll>><<permaview>><<newTiddler>><<newJournal "DD MMM YYYY" "journal">> /%<<slider chkSliderOptionsPanel OptionsPanel "options »" "Change TiddlyWiki advanced options">>%/
<<tabs txtMainTab
"Timeline" "Timeline" TabTimeline
"Tags" "All tags" TabTags
Index Index TabIndex
"More" "More lists" TabMore
>>
[[SyntaxHighlighterStyleSheet]]
/*{{{*/
#toggleSideBar {position:absolute; right:3px; top:-20px;}
#searchBar{position:absolute; right:20px; bottom:5px;}
/*.tabContents { background-color:White !important;}*/
.editor {
font-size: 12pt;
color: #402c74;
font-weight: normal;
padding: 10px 0;
}
.editor input, .editor textarea {
display: block;
font: 14px/130% "Andale Mono", "Monaco", "Lucida Console", "Courier New", monospace;
margin: 0;
border: 1px inset #333;
padding: 2px 0;
background: LightYellow;
}
/*}}}*/
!Download
:[[EMBEDDED FILE|syntaxhighlighterplugin4tiddlywiki]]
!Original Link
http://tiddlywiki.org/wiki/Syntax_Highlighting
!Instructions
Download 'syntaxhighlighterplugin.zip' from: http://www.coolcode.cn/?action=show&id=310 (look for the link near the top of the page) or my mirror: http://dl.getdropbox.com/u/52078/syntaxhighlighterplugin.zip
and extract...
Click the New Tiddler link to the left, and Name the tiddler 'StyleSheetSyntaxHighlighter' Navigate to your unzipped archive and cut and paste the contents of 'SyntaxHighlighter.css' into your new tiddler.
Navigate to the Shadow tiddler 'StyleSheet' and add [[StyleSheetSyntaxHighlighter]]
Add another 'New Tiddler' named 'SyntaxHighlighterPlugin' and paste the contents of 'shPlugin.js' into this tiddler, then tag the tiddler with 'systemConfig'
Finish everything up by copying 'clipboard.swf' to the directory of your TiddlyWiki... Make sure to save your changes, close and reopen your file to activate the plugin.
/***
!Metadata:
|''Name:''|SyntaxHighlighterPlugin|
|''Description:''|Code Syntax Highlighter Plugin for TiddlyWiki.|
|''Version:''|1.1.3|
|''Date:''|Oct 24, 2008|
|''Source:''|http://www.coolcode.cn/show-310-1.html|
|''Author:''|Ma Bingyao (andot (at) ujn (dot) edu (dot) cn)|
|''License:''|[[GNU Lesser General Public License|http://www.gnu.org/licenses/lgpl.txt]]|
|''~CoreVersion:''|2.4.1|
|''Browser:''|Firefox 1.5+; InternetExplorer 6.0; Safari; Opera; Chrome; etc.|
!Syntax:
{{{
<code options>
codes
</code>
}}}
!Examples:
{{{
<code java>
public class HelloWorld {
public static void main(String args[]) {
System.out.println("HelloWorld!");
}
}
</code>
}}}
!Revision History:
|''Version''|''Date''|''Note''|
|1.1.2|Oct 15, 2008|Optimize Highlight|
|1.0.0|Oct 13, 2008|Initial release|
!Code section:
***/
//{{{
var dp={sh:{Toolbar:{},Utils:{},RegexLib:{},Brushes:{},Strings:{AboutDialog:"<html><head><title>About...</title></head><body class=\"dp-about\"><table cellspacing=\"0\"><tr><td class=\"copy\"><p class=\"title\">dp.SyntaxHighlighter</div><div class=\"para\">Version: {V}</p><p><a href=\"http://www.dreamprojections.com/syntaxhighlighter/?ref=about\" target=\"_blank\">http://www.dreamprojections.com/syntaxhighlighter</a></p>©2004-2007 Alex Gorbatchev.</td></tr><tr><td class=\"footer\"><input type=\"button\" class=\"close\" value=\"OK\" onClick=\"window.close()\"/></td></tr></table></body></html>"},ClipboardSwf:null,Version:"1.5.1"}};dp.SyntaxHighlighter=dp.sh;dp.sh.Toolbar.Commands={ExpandSource:{label:"+ expand source",check:function($){return $.collapse},func:function($,_){$.parentNode.removeChild($);_.div.className=_.div.className.replace("collapsed","")}},ViewSource:{label:"view plain",func:function($,_){var A=dp.sh.Utils.FixForBlogger(_.originalCode).replace(/</g,"<"),B=window.open("","_blank","width=750, height=400, location=0, resizable=1, menubar=0, scrollbars=0");B.document.write("<textarea style=\"width:99%;height:99%\">"+A+"</textarea>");B.document.close()}},CopyToClipboard:{label:"copy to clipboard",check:function(){return window.clipboardData!=null||dp.sh.ClipboardSwf!=null},func:function($,A){var B=dp.sh.Utils.FixForBlogger(A.originalCode).replace(/</g,"<").replace(/>/g,">").replace(/&/g,"&");if(window.clipboardData)window.clipboardData.setData("text",B);else if(dp.sh.ClipboardSwf!=null){var _=A.flashCopier;if(_==null){_=document.createElement("div");A.flashCopier=_;A.div.appendChild(_)}_.innerHTML="<embed src=\""+dp.sh.ClipboardSwf+"\" FlashVars=\"clipboard="+encodeURIComponent(B)+"\" width=\"0\" height=\"0\" type=\"application/x-shockwave-flash\"></embed>"}displayMessage("The code is in your clipboard now")}},PrintSource:{label:"print",func:function($,B){var _=document.createElement("IFRAME"),A=null;_.style.cssText="position:absolute;width:0px;height:0px;left:-500px;top:-500px;";document.body.appendChild(_);A=_.contentWindow.document;dp.sh.Utils.CopyStyles(A,window.document);A.write("<div class=\""+B.div.className.replace("collapsed","")+" printing\">"+B.div.innerHTML+"</div>");A.close();_.contentWindow.focus();_.contentWindow.print();alert("Printing...");document.body.removeChild(_)}},About:{label:"?",func:function(_){var A=window.open("","_blank","dialog,width=300,height=150,scrollbars=0"),$=A.document;dp.sh.Utils.CopyStyles($,window.document);$.write(dp.sh.Strings.AboutDialog.replace("{V}",dp.sh.Version));$.close();A.focus()}}};dp.sh.Toolbar.Create=function(B){var A=document.createElement("DIV");A.className="tools";for(var _ in dp.sh.Toolbar.Commands){var $=dp.sh.Toolbar.Commands[_];if($.check!=null&&!$.check(B))continue;A.innerHTML+="<a href=\"#\" onclick=\"dp.sh.Toolbar.Command('"+_+"',this);return false;\">"+$.label+"</a>"}return A};dp.sh.Toolbar.Command=function(_,$){var A=$;while(A!=null&&A.className.indexOf("dp-highlighter")==-1)A=A.parentNode;if(A!=null)dp.sh.Toolbar.Commands[_].func($,A.highlighter)};dp.sh.Utils.CopyStyles=function(A,_){var $=_.getElementsByTagName("link");for(var B=0;B<$.length;B++)if($[B].rel.toLowerCase()=="stylesheet")A.write("<link type=\"text/css\" rel=\"stylesheet\" href=\""+$[B].href+"\"></link>")};dp.sh.Utils.FixForBlogger=function($){return(dp.sh.isBloggerMode==true)?$.replace(/<br\s*\/?>|<br\s*\/?>/gi,"\n"):$};dp.sh.RegexLib={MultiLineCComments:new RegExp("/\\*[\\s\\S]*?\\*/","gm"),SingleLineCComments:new RegExp("//.*$","gm"),SingleLinePerlComments:new RegExp("#.*$","gm"),DoubleQuotedString:new RegExp("\"(?:\\.|(\\\\\\\")|[^\\\"\"\\n])*\"","g"),SingleQuotedString:new RegExp("'(?:\\.|(\\\\\\')|[^\\''\\n])*'","g")};dp.sh.Match=function(_,$,A){this.value=_;this.index=$;this.length=_.length;this.css=A};dp.sh.Highlighter=function(){this.noGutter=false;this.addControls=true;this.collapse=false;this.tabsToSpaces=true;this.wrapColumn=80;this.showColumns=true};dp.sh.Highlighter.SortCallback=function($,_){if($.index<_.index)return-1;else if($.index>_.index)return 1;else if($.length<_.length)return-1;else if($.length>_.length)return 1;return 0};dp.sh.Highlighter.prototype.CreateElement=function(_){var $=document.createElement(_);$.highlighter=this;return $};dp.sh.Highlighter.prototype.GetMatches=function(_,B){var $=0,A=null;while((A=_.exec(this.code))!=null)this.matches[this.matches.length]=new dp.sh.Match(A[0],A.index,B)};dp.sh.Highlighter.prototype.AddBit=function($,A){if($==null||$.length==0)return;var C=this.CreateElement("SPAN");$=$.replace(/ /g," ");$=$.replace(/</g,"<");$=$.replace(/\n/gm," <br>");if(A!=null){if((/br/gi).test($)){var _=$.split(" <br>");for(var B=0;B<_.length;B++){C=this.CreateElement("SPAN");C.className=A;C.innerHTML=_[B];this.div.appendChild(C);if(B+1<_.length)this.div.appendChild(this.CreateElement("BR"))}}else{C.className=A;C.innerHTML=$;this.div.appendChild(C)}}else{C.innerHTML=$;this.div.appendChild(C)}};dp.sh.Highlighter.prototype.IsInside=function(_){if(_==null||_.length==0)return false;for(var A=0;A<this.matches.length;A++){var $=this.matches[A];if($==null)continue;if((_.index>$.index)&&(_.index<$.index+$.length))return true}return false};dp.sh.Highlighter.prototype.ProcessRegexList=function(){for(var $=0;$<this.regexList.length;$++)this.GetMatches(this.regexList[$].regex,this.regexList[$].css)};dp.sh.Highlighter.prototype.ProcessSmartTabs=function(E){var B=E.split("\n"),$="",D=4,A="\t";function _(A,E,_){var B=A.substr(0,E),C=A.substr(E+1,A.length),$="";for(var D=0;D<_;D++)$+=" ";return B+$+C}function C(B,C){if(B.indexOf(A)==-1)return B;var D=0;while((D=B.indexOf(A))!=-1){var $=C-D%C;B=_(B,D,$)}return B}for(var F=0;F<B.length;F++)$+=C(B[F],D)+"\n";return $};dp.sh.Highlighter.prototype.SwitchToList=function(){var C=this.div.innerHTML.replace(/<(br)\/?>/gi,"\n"),B=C.split("\n");if(this.addControls==true)this.bar.appendChild(dp.sh.Toolbar.Create(this));if(this.showColumns){var A=this.CreateElement("div"),_=this.CreateElement("div"),E=10,G=1;while(G<=150)if(G%E==0){A.innerHTML+=G;G+=(G+"").length}else{A.innerHTML+="·";G++}_.className="columns";_.appendChild(A);this.bar.appendChild(_)}for(var G=0,D=this.firstLine;G<B.length-1;G++,D++){var $=this.CreateElement("LI"),F=this.CreateElement("SPAN");$.className=(G%2==0)?"alt":"";F.innerHTML=B[G]+" ";$.appendChild(F);this.ol.appendChild($)}this.div.innerHTML=""};dp.sh.Highlighter.prototype.Highlight=function(C){function A($){return $.replace(/^\s*(.*?)[\s\n]*$/g,"$1")}function $($){return $.replace(/\n*$/,"").replace(/^\n*/,"")}function _(B){var E=dp.sh.Utils.FixForBlogger(B).split("\n"),C=new Array(),D=new RegExp("^\\s*","g"),$=1000;for(var F=0;F<E.length&&$>0;F++){if(A(E[F]).length==0)continue;var _=D.exec(E[F]);if(_!=null&&_.length>0)$=Math.min(_[0].length,$)}if($>0)for(F=0;F<E.length;F++)E[F]=E[F].substr($);return E.join("\n")}function D(A,$,_){return A.substr($,_-$)}var F=0;if(C==null)C="";this.originalCode=C;this.code=$(_(C));this.div=this.CreateElement("DIV");this.bar=this.CreateElement("DIV");this.ol=this.CreateElement("OL");this.matches=new Array();this.div.className="dp-highlighter";this.div.highlighter=this;this.bar.className="bar";this.ol.start=this.firstLine;if(this.CssClass!=null)this.ol.className=this.CssClass;if(this.collapse)this.div.className+=" collapsed";if(this.noGutter)this.div.className+=" nogutter";if(this.tabsToSpaces==true)this.code=this.ProcessSmartTabs(this.code);this.ProcessRegexList();if(this.matches.length==0){this.AddBit(this.code,null);this.SwitchToList();this.div.appendChild(this.bar);this.div.appendChild(this.ol);return}this.matches=this.matches.sort(dp.sh.Highlighter.SortCallback);for(var E=0;E<this.matches.length;E++)if(this.IsInside(this.matches[E]))this.matches[E]=null;for(E=0;E<this.matches.length;E++){var B=this.matches[E];if(B==null||B.length==0)continue;this.AddBit(D(this.code,F,B.index),null);this.AddBit(B.value,B.css);F=B.index+B.length}this.AddBit(this.code.substr(F),null);this.SwitchToList();this.div.appendChild(this.bar);this.div.appendChild(this.ol)};dp.sh.Highlighter.prototype.GetKeywords=function($){return"\\b"+$.replace(/ /g,"\\b|\\b")+"\\b"};dp.sh.BloggerMode=function(){dp.sh.isBloggerMode=true};dp.sh.HighlightAll=function(N,B,K,I,O,E){function A(){var $=arguments;for(var _=0;_<$.length;_++){if($[_]==null)continue;if(typeof($[_])=="string"&&$[_]!="")return $[_]+"";if(typeof($[_])=="object"&&$[_].value!="")return $[_].value+""}return null}function J($,_){for(var A=0;A<_.length;A++)if(_[A]==$)return true;return false}function L(A,B,C){var _=new RegExp("^"+A+"\\[(\\w+)\\]$","gi"),$=null;for(var D=0;D<B.length;D++)if(($=_.exec(B[D]))!=null)return $[1];return C}function C(B,A,_){var $=document.getElementsByTagName(_);for(var C=0;C<$.length;C++)if($[C].getAttribute("name")==A)B.push($[C])}var T=[],P=null,M={},$="innerHTML";C(T,N,"pre");C(T,N,"textarea");if(T.length==0)return;for(var R in dp.sh.Brushes){var F=dp.sh.Brushes[R].Aliases;if(F==null)continue;for(var G=0;G<F.length;G++)M[F[G]]=R}for(G=0;G<T.length;G++){var _=T[G],U=A(_.attributes["class"],_.className,_.attributes["language"],_.language),Q="";if(U==null)continue;U=U.split(":");Q=U[0].toLowerCase();if(M[Q]==null)continue;P=new dp.sh.Brushes[M[Q]]();_.style.display="none";P.noGutter=(B==null)?J("nogutter",U):!B;P.addControls=(K==null)?!J("nocontrols",U):K;P.collapse=(I==null)?J("collapse",U):I;P.showColumns=(E==null)?J("showcolumns",U):E;var D=document.getElementsByTagName("head")[0];if(P.Style&&D){var S=document.createElement("style");S.setAttribute("type","text/css");if(S.styleSheet)S.styleSheet.cssText=P.Style;else{var H=document.createTextNode(P.Style);S.appendChild(H)}D.appendChild(S)}P.firstLine=(O==null)?parseInt(L("firstline",U,1)):O;P.Highlight(_[$]);P.source=_;_.parentNode.insertBefore(P.div,_)}};version.extensions.SyntaxHighLighterPlugin={major:1,minor:1,revision:3,date:new Date(2008,10,24)};dp.sh.ClipboardSwf="clipboard.swf";dp.sh.Highlight=function(_,Q,B,J,H,M,D){function A(){var $=arguments;for(var _=0;_<$.length;_++){if($[_]==null)continue;if(typeof($[_])=="string"&&$[_]!="")return $[_]+"";if(typeof($[_])=="object"&&$[_].value!="")return $[_].value+""}return null}function I($,_){for(var A=0;A<_.length;A++)if(_[A]==$)return true;return false}function K(A,B,C){var _=new RegExp("^"+A+"\\[(\\w+)\\]$","gi"),$=null;for(var D=0;D<B.length;D++)if(($=_.exec(B[D]))!=null)return $[1];return C}var N=null,$="innerHTML";if(this.registered==undefined){var L={};for(var O in dp.sh.Brushes){var E=dp.sh.Brushes[O].Aliases;if(E==null)continue;for(var F=0;F<E.length;F++)L[E[F]]=O}this.registered=L}Q=Q.split(":");language=Q[0].toLowerCase();if(this.registered[language]==null)return;N=new dp.sh.Brushes[this.registered[language]]();_.style.display="none";N.noGutter=(B==null)?I("nogutter",Q):!B;N.addControls=(J==null)?!I("nocontrols",Q):J;N.collapse=(H==null)?I("collapse",Q):H;N.showColumns=(D==null)?I("showcolumns",Q):D;var C=document.getElementsByTagName("head")[0],P=document.getElementById(N.CssClass);if(N.Style&&C&&!P){P=document.createElement("style");P.setAttribute("id",N.CssClass);P.setAttribute("type","text/css");if(P.styleSheet)P.styleSheet.cssText=N.Style;else{var G=document.createTextNode(N.Style);P.appendChild(G)}C.appendChild(P)}N.firstLine=(M==null)?parseInt(K("firstline",Q,1)):M;N.Highlight(_[$]);N.source=_;_.parentNode.insertBefore(N.div,_)};config.formatters.push({name:"SyntaxHighlighter",match:"^<code[\\s]+[^>]+>\\n",element:"pre",handler:function(_){this.lookaheadRegExp=/<code[\s]+([^>]+)>\n((?:^[^\n]*\n)+?)(^<\/code>$\n?)/mg;this.lookaheadRegExp.lastIndex=_.matchStart;var $=this.lookaheadRegExp.exec(_.source);if($&&$.index==_.matchStart){var C=$[1],B=$[2];if(config.browser.isIE)B=B.replace(/\n/g,"\r");var A=createTiddlyElement(_.output,this.element,null,null,B);dp.sh.Highlight(A,C);_.nextMatch=$.index+$[0].length}}});config.formatterHelpers.enclosedTextHelper=function(_){this.lookaheadRegExp.lastIndex=_.matchStart;var $=this.lookaheadRegExp.exec(_.source);if($&&$.index==_.matchStart){var B=$[1];if(config.browser.isIE)B=B.replace(/\n/g,"\r");var A=createTiddlyElement(_.output,this.element,null,null,B);switch(_.matchText){case"/*{{{*/\n":dp.sh.Highlight(A,"css");break;case"//{{{\n":dp.sh.Highlight(A,"js");break;case"<!--{{{-->\n":dp.sh.Highlight(A,"xml");break}_.nextMatch=$.index+$[0].length}};dp.sh.Brushes.AS3=function(){var _="class interface package",$="Array Boolean Date decodeURI decodeURIComponent encodeURI encodeURIComponent escape "+"int isFinite isNaN isXMLName Number Object parseFloat parseInt "+"String trace uint unescape XML XMLList "+"Infinity -Infinity NaN undefined "+"as delete instanceof is new typeof "+"break case catch continue default do each else finally for if in "+"label return super switch throw try while with "+"dynamic final internal native override private protected public static "+"...rest const extends function get implements namespace set "+"import include use "+"AS3 flash_proxy object_proxy "+"false null this true "+"void Null";this.regexList=[{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.MultiLineCComments,css:"blockcomment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("^\\s*#.*","gm"),css:"preprocessor"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"definition"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"},{regex:new RegExp("var","gm"),css:"variable"}];this.CssClass="dp-as";this.Style=".dp-as .comment { color: #009900; font-style: italic; }"+".dp-as .blockcomment { color: #3f5fbf; }"+".dp-as .string { color: #990000; }"+".dp-as .preprocessor { color: #0033ff; }"+".dp-as .definition { color: #9900cc; font-weight: bold; }"+".dp-as .keyword { color: #0033ff; }"+".dp-as .variable { color: #6699cc; font-weight: bold; }"};dp.sh.Brushes.AS3.prototype=new dp.sh.Highlighter();dp.sh.Brushes.AS3.Aliases=["as","actionscript","ActionScript","as3","AS3"];dp.sh.Brushes.Bash=function(){var _="alias bg bind break builtin cd command compgen complete continue "+"declare dirs disown echo enable eval exec exit export fc fg "+"getopts hash help history jobs kill let local logout popd printf "+"pushd pwd read readonly return set shift shopt source "+"suspend test times trap type typeset ulimit umask unalias unset wait",$="case do done elif else esac fi for function if in select then "+"time until while";this.regexList=[{regex:dp.sh.RegexLib.SingleLinePerlComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("[()[\\]{}]","g"),css:"delim"},{regex:new RegExp("\\$\\w+","g"),css:"vars"},{regex:new RegExp("\\w+=","g"),css:"vars"},{regex:new RegExp("\\s-\\w+","g"),css:"flag"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"builtin"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-bash";this.Style=".dp-bash .builtin {color: maroon; font-weight: bold;}"+".dp-bash .comment {color: gray;}"+".dp-bash .delim {font-weight: bold;}"+".dp-bash .flag {color: green;}"+".dp-bash .string {color: red;}"+".dp-bash .vars {color: blue;}"};dp.sh.Brushes.Bash.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Bash.Aliases=["bash","sh"];dp.sh.Brushes.Batch=function(){var _="APPEND ATTRIB CD CHDIR CHKDSK CHOICE CLS COPY DEL ERASE DELTREE "+"DIR EXIT FC COMP FDISK FIND FORMAT FSUTIL HELP JOIN "+"LABEL LOADFIX MK MKDIR MEM MEMMAKER MORE MOVE MSD PCPARK "+"PRINT RD RMDIR REN SCANDISK SHARE SORT SUBST SYS "+"TIME DATE TREE TRUENAME TYPE UNDELETE VER XCOPY",$="DO ELSE FOR IN CALL CHOICE GOTO SHIFT PAUSE ERRORLEVEL "+"IF NOT EXIST LFNFOR START SETLOCAL ENDLOCAL ECHO SET";this.regexList=[{regex:new RegExp("REM.*$","gm"),css:"comment"},{regex:new RegExp("::.*$","gm"),css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("[()[\\]{}]","g"),css:"delim"},{regex:new RegExp("%\\w+%","g"),css:"vars"},{regex:new RegExp("%%\\w+","g"),css:"vars"},{regex:new RegExp("\\w+=","g"),css:"vars"},{regex:new RegExp("@\\w+","g"),css:"keyword"},{regex:new RegExp(":\\w+","g"),css:"keyword"},{regex:new RegExp("\\s/\\w+","g"),css:"flag"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"builtin"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-batch";this.Style=".dp-batch .builtin {color: maroon; font-weight: bold;}"+".dp-batch .comment {color: gray;}"+".dp-batch .delim {font-weight: bold;}"+".dp-batch .flag {color: green;}"+".dp-batch .string {color: red;}"+".dp-batch .vars {color: blue;font-weight: bold;}"};dp.sh.Brushes.Batch.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Batch.Aliases=["batch","dos"];dp.sh.Brushes.ColdFusion=function(){this.CssClass="dp-coldfusion";this.Style=".dp-coldfusion { font: 13px \"Courier New\", Courier, monospace; }"+".dp-coldfusion .tag, .dp-coldfusion .tag-name { color: #990033; }"+".dp-coldfusion .attribute { color: #990033; }"+".dp-coldfusion .attribute-value { color: #0000FF; }"+".dp-coldfusion .cfcomments { background-color: #FFFF99; color: #000000; }"+".dp-coldfusion .cfscriptcomments { color: #999999; }"+".dp-coldfusion .keywords { color: #0000FF; }"+".dp-coldfusion .mgkeywords { color: #CC9900; }"+".dp-coldfusion .numbers { color: #ff0000; }"+".dp-coldfusion .strings { color: green; }";this.mgKeywords="setvalue getvalue addresult viewcollection viewstate";this.keywords="var eq neq gt gte lt lte not and or true false "+"abs acos addsoaprequestheader addsoapresponseheader "+"arrayappend arrayavg arrayclear arraydeleteat arrayinsertat "+"arrayisempty arraylen arraymax arraymin arraynew "+"arrayprepend arrayresize arrayset arraysort arraysum "+"arrayswap arraytolist asc asin atn binarydecode binaryencode "+"bitand bitmaskclear bitmaskread bitmaskset bitnot bitor bitshln "+"bitshrn bitxor ceiling charsetdecode charsetencode chr cjustify "+"compare comparenocase cos createdate createdatetime createobject "+"createobject createobject createobject createobject createodbcdate "+"createodbcdatetime createodbctime createtime createtimespan "+"createuuid dateadd datecompare dateconvert datediff dateformat "+"datepart day dayofweek dayofweekasstring dayofyear daysinmonth "+"daysinyear de decimalformat decrementvalue decrypt decryptbinary "+"deleteclientvariable directoryexists dollarformat duplicate encrypt "+"encryptbinary evaluate exp expandpath fileexists find findnocase "+"findoneof firstdayofmonth fix formatbasen generatesecretkey "+"getauthuser getbasetagdata getbasetaglist getbasetemplatepath "+"getclientvariableslist getcontextroot getcurrenttemplatepath "+"getdirectoryfrompath getencoding getexception getfilefrompath "+"getfunctionlist getgatewayhelper gethttprequestdata gethttptimestring "+"getk2serverdoccount getk2serverdoccountlimit getlocale "+"getlocaledisplayname getlocalhostip getmetadata getmetricdata "+"getpagecontext getprofilesections getprofilestring getsoaprequest "+"getsoaprequestheader getsoapresponse getsoapresponseheader "+"gettempdirectory gettempfile gettemplatepath gettickcount "+"gettimezoneinfo gettoken hash hour htmlcodeformat htmleditformat "+"iif incrementvalue inputbasen insert int isarray isbinary isboolean "+"iscustomfunction isdate isdebugmode isdefined isk2serverabroker "+"isk2serverdoccountexceeded isk2serveronline isleapyear islocalhost "+"isnumeric isnumericdate isobject isquery issimplevalue issoaprequest "+"isstruct isuserinrole isvalid isvalid isvalid iswddx isxml "+"isxmlattribute isxmldoc isxmlelem isxmlnode isxmlroot javacast "+"jsstringformat lcase left len listappend listchangedelims listcontains "+"listcontainsnocase listdeleteat listfind listfindnocase listfirst "+"listgetat listinsertat listlast listlen listprepend listqualify "+"listrest listsetat listsort listtoarray listvaluecount "+"listvaluecountnocase ljustify log log10 lscurrencyformat lsdateformat "+"lseurocurrencyformat lsiscurrency lsisdate lsisnumeric lsnumberformat "+"lsparsecurrency lsparsedatetime lsparseeurocurrency lsparsenumber "+"lstimeformat ltrim max mid min minute month monthasstring now "+"numberformat paragraphformat parameterexists parsedatetime pi "+"preservesinglequotes quarter queryaddcolumn queryaddrow querynew "+"querysetcell quotedvaluelist rand randomize randrange refind "+"refindnocase releasecomobject removechars repeatstring replace "+"replacelist replacenocase rereplace rereplacenocase reverse right "+"rjustify round rtrim second sendgatewaymessage setencoding "+"setlocale setprofilestring setvariable sgn sin spanexcluding "+"spanincluding sqr stripcr structappend structclear structcopy "+"structcount structdelete structfind structfindkey structfindvalue "+"structget structinsert structisempty structkeyarray structkeyexists "+"structkeylist structnew structsort structupdate tan timeformat "+"tobase64 tobinary toscript tostring trim ucase urldecode urlencodedformat "+"urlsessionformat val valuelist week wrap writeoutput xmlchildpos "+"xmlelemnew xmlformat xmlgetnodetype xmlnew xmlparse xmlsearch xmltransform "+"xmlvalidate year yesnoformat";this.stringMatches=new Array();this.attributeMatches=new Array()};dp.sh.Brushes.ColdFusion.prototype=new dp.sh.Highlighter();dp.sh.Brushes.ColdFusion.Aliases=["coldfusion","cf"];dp.sh.Brushes.ColdFusion.prototype.ProcessRegexList=function(){function B(_,$){_[_.length]=$}function A(A,$){for(var _=0;_<A.length;_++)if(A[_]==$)return _;return-1}var _=null,$=null;this.GetMatches(new RegExp("\\b(\\d+)","gm"),"numbers");this.GetMatches(new RegExp(this.GetKeywords(this.mgKeywords),"igm"),"mgkeywords");this.GetMatches(dp.sh.RegexLib.SingleLineCComments,"cfscriptcomments");this.GetMatches(dp.sh.RegexLib.MultiLineCComments,"cfscriptcomments");this.GetMatches(new RegExp("(<|<)!---[\\s\\S]*?---(>|>)","gm"),"cfcomments");$=new RegExp("(cfset\\s*)?([:\\w-.]+)\\s*=\\s*(\".*?\"|'.*?')*","gm");while((_=$.exec(this.code))!=null){if(_[1]!=undefined&&_[1]!="")continue;if(_[3]!=undefined&&_[3]!=""&&_[3]!="\"\""&&_[3]!="''"){B(this.matches,new dp.sh.Match(_[2],_.index,"attribute"));B(this.matches,new dp.sh.Match(_[3],_.index+_[0].indexOf(_[3]),"attribute-value"));B(this.stringMatches,_[3]);B(this.attributeMatches,_[2])}}this.GetMatches(new RegExp("(<|<)/*\\?*(?!\\!)|/*\\?*(>|>)","gm"),"tag");$=new RegExp("(?:<|<)/*\\?*\\s*([:\\w-.]+)","gm");while((_=$.exec(this.code))!=null)B(this.matches,new dp.sh.Match(_[1],_.index+_[0].indexOf(_[1]),"tag-name"));$=new RegExp(this.GetKeywords(this.keywords),"igm");while((_=$.exec(this.code))!=null)if(A(this.attributeMatches,_[0])==-1)B(this.matches,new dp.sh.Match(_[0],_.index,"keywords"));$=new RegExp("cfset\\s*.*(\".*?\"|'.*?')","gm");while((_=$.exec(this.code))!=null)if(_[1]!=undefined&&_[1]!=""){B(this.matches,new dp.sh.Match(_[1],_.index+_[0].indexOf(_[1]),"strings"));B(this.stringMatches,_[1])}while((_=dp.sh.RegexLib.DoubleQuotedString.exec(this.code))!=null)if(A(this.stringMatches,_[0])==-1)B(this.matches,new dp.sh.Match(_[0],_.index,"strings"));while((_=dp.sh.RegexLib.SingleQuotedString.exec(this.code))!=null)if(A(this.stringMatches,_[0])==-1)B(this.matches,new dp.sh.Match(_[0],_.index,"strings"))};dp.sh.Brushes.Cpp=function(){var _="ATOM BOOL BOOLEAN BYTE CHAR COLORREF DWORD DWORDLONG DWORD_PTR "+"DWORD32 DWORD64 FLOAT HACCEL HALF_PTR HANDLE HBITMAP HBRUSH "+"HCOLORSPACE HCONV HCONVLIST HCURSOR HDC HDDEDATA HDESK HDROP HDWP "+"HENHMETAFILE HFILE HFONT HGDIOBJ HGLOBAL HHOOK HICON HINSTANCE HKEY "+"HKL HLOCAL HMENU HMETAFILE HMODULE HMONITOR HPALETTE HPEN HRESULT "+"HRGN HRSRC HSZ HWINSTA HWND INT INT_PTR INT32 INT64 LANGID LCID LCTYPE "+"LGRPID LONG LONGLONG LONG_PTR LONG32 LONG64 LPARAM LPBOOL LPBYTE LPCOLORREF "+"LPCSTR LPCTSTR LPCVOID LPCWSTR LPDWORD LPHANDLE LPINT LPLONG LPSTR LPTSTR "+"LPVOID LPWORD LPWSTR LRESULT PBOOL PBOOLEAN PBYTE PCHAR PCSTR PCTSTR PCWSTR "+"PDWORDLONG PDWORD_PTR PDWORD32 PDWORD64 PFLOAT PHALF_PTR PHANDLE PHKEY PINT "+"PINT_PTR PINT32 PINT64 PLCID PLONG PLONGLONG PLONG_PTR PLONG32 PLONG64 POINTER_32 "+"POINTER_64 PSHORT PSIZE_T PSSIZE_T PSTR PTBYTE PTCHAR PTSTR PUCHAR PUHALF_PTR "+"PUINT PUINT_PTR PUINT32 PUINT64 PULONG PULONGLONG PULONG_PTR PULONG32 PULONG64 "+"PUSHORT PVOID PWCHAR PWORD PWSTR SC_HANDLE SC_LOCK SERVICE_STATUS_HANDLE SHORT "+"SIZE_T SSIZE_T TBYTE TCHAR UCHAR UHALF_PTR UINT UINT_PTR UINT32 UINT64 ULONG "+"ULONGLONG ULONG_PTR ULONG32 ULONG64 USHORT USN VOID WCHAR WORD WPARAM WPARAM WPARAM "+"char bool short int __int32 __int64 __int8 __int16 long float double __wchar_t "+"clock_t _complex _dev_t _diskfree_t div_t ldiv_t _exception _EXCEPTION_POINTERS "+"FILE _finddata_t _finddatai64_t _wfinddata_t _wfinddatai64_t __finddata64_t "+"__wfinddata64_t _FPIEEE_RECORD fpos_t _HEAPINFO _HFILE lconv intptr_t "+"jmp_buf mbstate_t _off_t _onexit_t _PNH ptrdiff_t _purecall_handler "+"sig_atomic_t size_t _stat __stat64 _stati64 terminate_function "+"time_t __time64_t _timeb __timeb64 tm uintptr_t _utimbuf "+"va_list wchar_t wctrans_t wctype_t wint_t signed",$="break case catch class const __finally __exception __try "+"const_cast continue private public protected __declspec "+"default delete deprecated dllexport dllimport do dynamic_cast "+"else enum explicit extern if for friend goto inline "+"mutable naked namespace new noinline noreturn nothrow "+"register reinterpret_cast return selectany "+"sizeof static static_cast struct switch template this "+"thread throw true false try typedef typeid typename union "+"using uuid virtual void volatile whcar_t while";this.regexList=[{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.MultiLineCComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("^ *#.*","gm"),css:"preprocessor"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"datatypes"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-cpp";this.Style=".dp-cpp .datatypes { color: #2E8B57; font-weight: bold; }"};dp.sh.Brushes.Cpp.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Cpp.Aliases=["cpp","c","c++"];dp.sh.Brushes.CSharp=function(){var $="abstract as base bool break byte case catch char checked class const "+"continue decimal default delegate do double else enum event explicit "+"extern false finally fixed float for foreach get goto if implicit in int "+"interface internal is lock long namespace new null object operator out "+"override params private protected public readonly ref return sbyte sealed set "+"short sizeof stackalloc static string struct switch this throw true try "+"typeof uint ulong unchecked unsafe ushort using virtual void while";this.regexList=[{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.MultiLineCComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("^\\s*#.*","gm"),css:"preprocessor"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-c";this.Style=".dp-c .vars { color: #d00; }"};dp.sh.Brushes.CSharp.prototype=new dp.sh.Highlighter();dp.sh.Brushes.CSharp.Aliases=["c#","c-sharp","csharp"];dp.sh.Brushes.CSS=function(){var _="ascent azimuth background-attachment background-color background-image background-position "+"background-repeat background baseline bbox border-collapse border-color border-spacing border-style border-top "+"border-right border-bottom border-left border-top-color border-right-color border-bottom-color border-left-color "+"border-top-style border-right-style border-bottom-style border-left-style border-top-width border-right-width "+"border-bottom-width border-left-width border-width border cap-height caption-side centerline clear clip color "+"content counter-increment counter-reset cue-after cue-before cue cursor definition-src descent direction display "+"elevation empty-cells float font-size-adjust font-family font-size font-stretch font-style font-variant font-weight font "+"height letter-spacing line-height list-style-image list-style-position list-style-type list-style margin-top "+"margin-right margin-bottom margin-left margin marker-offset marks mathline max-height max-width min-height min-width orphans "+"outline-color outline-style outline-width outline overflow padding-top padding-right padding-bottom padding-left padding page "+"page-break-after page-break-before page-break-inside pause pause-after pause-before pitch pitch-range play-during position "+"quotes richness size slope src speak-header speak-numeral speak-punctuation speak speech-rate stemh stemv stress "+"table-layout text-align text-decoration text-indent text-shadow text-transform unicode-bidi unicode-range units-per-em "+"vertical-align visibility voice-family volume white-space widows width widths word-spacing x-height z-index",$="above absolute all always aqua armenian attr aural auto avoid baseline behind below bidi-override black blink block blue bold bolder "+"both bottom braille capitalize caption center center-left center-right circle close-quote code collapse compact condensed "+"continuous counter counters crop cross crosshair cursive dashed decimal decimal-leading-zero default digits disc dotted double "+"embed embossed e-resize expanded extra-condensed extra-expanded fantasy far-left far-right fast faster fixed format fuchsia "+"gray green groove handheld hebrew help hidden hide high higher icon inline-table inline inset inside invert italic "+"justify landscape large larger left-side left leftwards level lighter lime line-through list-item local loud lower-alpha "+"lowercase lower-greek lower-latin lower-roman lower low ltr marker maroon medium message-box middle mix move narrower "+"navy ne-resize no-close-quote none no-open-quote no-repeat normal nowrap n-resize nw-resize oblique olive once open-quote outset "+"outside overline pointer portrait pre print projection purple red relative repeat repeat-x repeat-y rgb ridge right right-side "+"rightwards rtl run-in screen scroll semi-condensed semi-expanded separate se-resize show silent silver slower slow "+"small small-caps small-caption smaller soft solid speech spell-out square s-resize static status-bar sub super sw-resize "+"table-caption table-cell table-column table-column-group table-footer-group table-header-group table-row table-row-group teal "+"text-bottom text-top thick thin top transparent tty tv ultra-condensed ultra-expanded underline upper-alpha uppercase upper-latin "+"upper-roman url visible wait white wider w-resize x-fast x-high x-large x-loud x-low x-slow x-small x-soft xx-large xx-small yellow",A="[mM]onospace [tT]ahoma [vV]erdana [aA]rial [hH]elvetica [sS]ans-serif [sS]erif";this.regexList=[{regex:dp.sh.RegexLib.MultiLineCComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("\\#[a-zA-Z0-9]{3,6}","g"),css:"value"},{regex:new RegExp("(-?\\d+)(.\\d+)?(px|em|pt|:|%|)","g"),css:"value"},{regex:new RegExp("!important","g"),css:"important"},{regex:new RegExp(this.GetKeywordsCSS(_),"gm"),css:"keyword"},{regex:new RegExp(this.GetValuesCSS($),"g"),css:"value"},{regex:new RegExp(this.GetValuesCSS(A),"g"),css:"value"}];this.CssClass="dp-css";this.Style=".dp-css .value { color: black; }"+".dp-css .important { color: red; }"};dp.sh.Highlighter.prototype.GetKeywordsCSS=function($){return"\\b([a-z_]|)"+$.replace(/ /g,"(?=:)\\b|\\b([a-z_\\*]|\\*|)")+"(?=:)\\b"};dp.sh.Highlighter.prototype.GetValuesCSS=function($){return"\\b"+$.replace(/ /g,"(?!-)(?!:)\\b|\\b()")+":\\b"};dp.sh.Brushes.CSS.prototype=new dp.sh.Highlighter();dp.sh.Brushes.CSS.Aliases=["css"];dp.sh.Brushes.Delphi=function(){var $="abs addr and ansichar ansistring array as asm begin boolean byte cardinal "+"case char class comp const constructor currency destructor div do double "+"downto else end except exports extended false file finalization finally "+"for function goto if implementation in inherited int64 initialization "+"integer interface is label library longint longword mod nil not object "+"of on or packed pansichar pansistring pchar pcurrency pdatetime pextended "+"pint64 pointer private procedure program property pshortstring pstring "+"pvariant pwidechar pwidestring protected public published raise real real48 "+"record repeat set shl shortint shortstring shr single smallint string then "+"threadvar to true try type unit until uses val var varirnt while widechar "+"widestring with word write writeln xor";this.regexList=[{regex:new RegExp("\\(\\*[\\s\\S]*?\\*\\)","gm"),css:"comment"},{regex:new RegExp("{(?!\\$)[\\s\\S]*?}","gm"),css:"comment"},{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("\\{\\$[a-zA-Z]+ .+\\}","g"),css:"directive"},{regex:new RegExp("\\b[\\d\\.]+\\b","g"),css:"number"},{regex:new RegExp("\\$[a-zA-Z0-9]+\\b","g"),css:"number"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-delphi";this.Style=".dp-delphi .number { color: blue; }"+".dp-delphi .directive { color: #008284; }"+".dp-delphi .vars { color: #000; }"};dp.sh.Brushes.Delphi.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Delphi.Aliases=["delphi","pascal"];dp.sh.Brushes.Java=function(){var $="abstract assert boolean break byte case catch char class const "+"continue default do double else enum extends "+"false final finally float for goto if implements import "+"instanceof int interface long native new null "+"package private protected public return "+"short static strictfp super switch synchronized this throw throws true "+"transient try void volatile while";this.regexList=[{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.MultiLineCComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("\\b([\\d]+(\\.[\\d]+)?|0x[a-f0-9]+)\\b","gi"),css:"number"},{regex:new RegExp("(?!\\@interface\\b)\\@[\\$\\w]+\\b","g"),css:"annotation"},{regex:new RegExp("\\@interface\\b","g"),css:"keyword"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-j";this.Style=".dp-j .annotation { color: #646464; }"+".dp-j .number { color: #C00000; }"};dp.sh.Brushes.Java.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Java.Aliases=["java"];dp.sh.Brushes.JScript=function(){var $="abstract boolean break byte case catch char class const continue debugger "+"default delete do double else enum export extends false final finally float "+"for function goto if implements import in instanceof int interface long native "+"new null package private protected public return short static super switch "+"synchronized this throw throws transient true try typeof var void volatile while with";this.regexList=[{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.MultiLineCComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("^\\s*#.*","gm"),css:"preprocessor"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-c"};dp.sh.Brushes.JScript.prototype=new dp.sh.Highlighter();dp.sh.Brushes.JScript.Aliases=["js","jscript","javascript"];dp.sh.Brushes.Lua=function(){var $="break do end else elseif function if local nil not or repeat return and then until while this",_="math\\.\\w+ string\\.\\w+ os\\.\\w+ debug\\.\\w+ io\\.\\w+ error fopen dofile coroutine\\.\\w+ arg getmetatable ipairs loadfile loadlib loadstring longjmp print rawget rawset seek setmetatable assert tonumber tostring";this.regexList=[{regex:new RegExp("--\\[\\[[\\s\\S]*\\]\\]--","gm"),css:"comment"},{regex:new RegExp("--[^\\[]{2}.*$","gm"),css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"func"},];this.CssClass="dp-lua"};dp.sh.Brushes.Lua.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Lua.Aliases=["lua"];dp.sh.Brushes.Mxml=function(){this.CssClass="dp-mxml";this.Style=".dp-mxml .cdata { color: #000000; }"+".dp-mxml .tag { color : #0000ff; }"+".dp-mxml .tag-name { color: #0000ff; }"+".dp-mxml .script { color: green; }"+".dp-mxml .metadata { color: green; }"+".dp-mxml .attribute { color: #000000; }"+".dp-mxml .attribute-value { color: #990000; }"+".dp-mxml .trace { color: #cc6666; }"+".dp-mxml .var { color: #6699cc; }"+".dp-mxml .comment { color: #009900; }"+".dp-mxml .string { color: #990000; }"+".dp-mxml .keyword { color: blue; }"};dp.sh.Brushes.Mxml.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Mxml.Aliases=["mxml"];dp.sh.Brushes.Mxml.prototype.ProcessRegexList=function(){function H(_,$){_[_.length]=$}function B(B,_){var A=0,$=false;for(A=0;A<B.length;A++)if(_.index>B[A].firstIndex&&_.index<B[A].lastIndex)$=true;return $}var $=0,F=null,D=null,A=null,C="",E=new Array(),_="abstract boolean break byte case catch char class const continue debugger "+"default delete do double else enum export extends false final finally float "+"for function goto if implements import in instanceof int interface long native "+"new null package private protected public return short static super switch "+"synchronized this throw throws transient true try typeof var void volatile while with",G=[{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.MultiLineCComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("^\\s*#.*","gm"),css:"preprocessor"},{regex:new RegExp(this.GetKeywords("trace"),"gm"),css:"trace"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"keyword"}];A=new RegExp("<\\!\\[CDATA\\[(.|\\s)*?\\]\\]>","gm");while((F=A.exec(this.code))!=null){C=F[0].substr(0,12);H(this.matches,new dp.sh.Match(C,F.index,"cdata"));C=F[0].substr(12,F[0].length-12-6);for(var I=0;I<G.length;I++)while((D=G[I].regex.exec(C))!=null)H(this.matches,new dp.sh.Match(D[0],F.index+12+D.index,G[I].css));C=F[0].substr(F[0].length-6,6);H(this.matches,new dp.sh.Match(C,F.index+F[0].length-6,"cdata"));E.push({firstIndex:F.index,lastIndex:F.index+F[0].length-1})}this.GetMatches(new RegExp("(<|<)!--\\s*.*?\\s*--(>|>)","gm"),"comments");A=new RegExp("([:\\w-.]+)\\s*=\\s*(\".*?\"|'.*?'|\\w+)*|(\\w+)","gm");while((F=A.exec(this.code))!=null){if(F[1]==null)continue;if(B(E,F))continue;H(this.matches,new dp.sh.Match(F[1],F.index,"attribute"));if(F[2]!=undefined)H(this.matches,new dp.sh.Match(F[2],F.index+F[0].indexOf(F[2]),"attribute-value"))}A=new RegExp("(?:<|<)/*\\?*\\s*([:\\w-.]+)","gm");while((F=A.exec(this.code))!=null){if(B(E,F))continue;C=F[0].substr(4,F[0].length-4);switch(C){case"mx:Script":case"/mx:Script":H(this.matches,new dp.sh.Match(F[0]+">",F.index,"script"));break;case"mx:Metadata":case"/mx:Metadata":H(this.matches,new dp.sh.Match(F[0]+">",F.index,"metadata"));break;default:H(this.matches,new dp.sh.Match(F[0],F.index,"tag-name"));break}}A=new RegExp("\\?>|>|/>","gm");while((F=A.exec(this.code))!=null){if(B(E,F))continue;H(this.matches,new dp.sh.Match(F[0],F.index,"tag"))}};dp.sh.Brushes.Perl=function(){var _="abs accept alarm atan2 bind binmode bless caller chdir chmod chomp chop chown chr chroot close closedir connect cos crypt dbmclose dbmopen defined delete dump each endgrent endhostent endnetent endprotoent endpwent endservent eof exec exists exp fcntl fileno flock fork format formline getc getgrent getgrgid getgrnam gethostbyaddr gethostbyname gethostent getlogin getnetbyaddr getnetbyname getnetent getpeername getpgrp getppid getpriority getprotobyname getprotobynumber getprotoent getpwent getpwnam getpwuid getservbyname getservbyport getservent getsockname getsockopt glob gmtime grep hex import index int ioctl join keys kill lc lcfirst length link listen localtime lock log lstat m map mkdir msgctl msgget msgrcv msgsnd no oct open opendir ord pack pipe pop pos print printf prototype push q qq quotemeta qw qx rand read readdir readline readlink readpipe recv ref rename reset reverse rewinddir rindex rmdir scalar seek seekdir semctl semget semop send setgrent sethostent setnetent setpgrp setpriority setprotoent setpwent setservent setsockopt shift shmctl shmget shmread shmwrite shutdown sin sleep socket socketpair sort splice split sprintf sqrt srand stat study sub substr symlink syscall sysopen sysread sysseek system syswrite tell telldir tie tied time times tr truncate uc ucfirst umask undef unlink unpack unshift untie utime values vec waitpid wantarray warn write qr",$="s select goto die do package redo require return continue for foreach last next wait while use if else elsif eval exit unless switch case",A="my our local";this.regexList=[{regex:dp.sh.RegexLib.SingleLinePerlComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("(\\$|@|%)\\w+","g"),css:"vars"},{regex:new RegExp(this.GetKeywords(_),"gmi"),css:"func"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"},{regex:new RegExp(this.GetKeywords(A),"gm"),css:"declarations"}];this.CssClass="dp-perl"};dp.sh.Brushes.Perl.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Perl.Aliases=["perl"];dp.sh.Brushes.Php=function(){var _="abs acos acosh addcslashes addslashes "+"array_change_key_case array_chunk array_combine array_count_values array_diff "+"array_diff_assoc array_diff_key array_diff_uassoc array_diff_ukey array_fill "+"array_filter array_flip array_intersect array_intersect_assoc array_intersect_key "+"array_intersect_uassoc array_intersect_ukey array_key_exists array_keys array_map "+"array_merge array_merge_recursive array_multisort array_pad array_pop array_product "+"array_push array_rand array_reduce array_reverse array_search array_shift "+"array_slice array_splice array_sum array_udiff array_udiff_assoc "+"array_udiff_uassoc array_uintersect array_uintersect_assoc "+"array_uintersect_uassoc array_unique array_unshift array_values array_walk "+"array_walk_recursive atan atan2 atanh base64_decode base64_encode base_convert "+"basename bcadd bccomp bcdiv bcmod bcmul bindec bindtextdomain bzclose bzcompress "+"bzdecompress bzerrno bzerror bzerrstr bzflush bzopen bzread bzwrite ceil chdir "+"checkdate checkdnsrr chgrp chmod chop chown chr chroot chunk_split class_exists "+"closedir closelog copy cos cosh count count_chars date decbin dechex decoct "+"deg2rad delete ebcdic2ascii echo empty end ereg ereg_replace eregi eregi_replace error_log "+"error_reporting escapeshellarg escapeshellcmd eval exec exit exp explode extension_loaded "+"feof fflush fgetc fgetcsv fgets fgetss file_exists file_get_contents file_put_contents "+"fileatime filectime filegroup fileinode filemtime fileowner fileperms filesize filetype "+"floatval flock floor flush fmod fnmatch fopen fpassthru fprintf fputcsv fputs fread fscanf "+"fseek fsockopen fstat ftell ftok getallheaders getcwd getdate getenv gethostbyaddr gethostbyname "+"gethostbynamel getimagesize getlastmod getmxrr getmygid getmyinode getmypid getmyuid getopt "+"getprotobyname getprotobynumber getrandmax getrusage getservbyname getservbyport gettext "+"gettimeofday gettype glob gmdate gmmktime ini_alter ini_get ini_get_all ini_restore ini_set "+"interface_exists intval ip2long is_a is_array is_bool is_callable is_dir is_double "+"is_executable is_file is_finite is_float is_infinite is_int is_integer is_link is_long "+"is_nan is_null is_numeric is_object is_readable is_real is_resource is_scalar is_soap_fault "+"is_string is_subclass_of is_uploaded_file is_writable is_writeable mkdir mktime nl2br "+"parse_ini_file parse_str parse_url passthru pathinfo readlink realpath rewind rewinddir rmdir "+"round str_ireplace str_pad str_repeat str_replace str_rot13 str_shuffle str_split "+"str_word_count strcasecmp strchr strcmp strcoll strcspn strftime strip_tags stripcslashes "+"stripos stripslashes stristr strlen strnatcasecmp strnatcmp strncasecmp strncmp strpbrk "+"strpos strptime strrchr strrev strripos strrpos strspn strstr strtok strtolower strtotime "+"strtoupper strtr strval substr substr_compare",$="and or xor __FILE__ __LINE__ array as break case "+"cfunction class const continue declare default die do else "+"elseif empty enddeclare endfor endforeach endif endswitch endwhile "+"extends for foreach function include include_once global if "+"new old_function return static switch use require require_once "+"var while __FUNCTION__ __CLASS__ "+"__METHOD__ abstract interface public implements extends private protected throw";this.regexList=[{regex:dp.sh.RegexLib.SingleLineCComments,css:"comment"},{regex:dp.sh.RegexLib.MultiLineCComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp("\\$\\w+","g"),css:"vars"},{regex:new RegExp(this.GetKeywords(_),"gmi"),css:"func"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-c"};dp.sh.Brushes.Php.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Php.Aliases=["php"];dp.sh.Brushes.Python=function(){var $="and assert break class continue def del elif else "+"except exec finally for from global if import in is "+"lambda not or pass print raise return try yield while",_="None True False self cls class_";this.regexList=[{regex:dp.sh.RegexLib.SingleLinePerlComments,css:"comment"},{regex:new RegExp("^\\s*@\\w+","gm"),css:"decorator"},{regex:new RegExp("(['\"]{3})([^\\1])*?\\1","gm"),css:"comment"},{regex:new RegExp("\"(?!\")(?:\\.|\\\\\\\"|[^\\\"\"\\n\\r])*\"","gm"),css:"string"},{regex:new RegExp("'(?!')*(?:\\.|(\\\\\\')|[^\\''\\n\\r])*'","gm"),css:"string"},{regex:new RegExp("\\b\\d+\\.?\\w*","g"),css:"number"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"special"}];this.CssClass="dp-py";this.Style=".dp-py .builtins { color: #ff1493; }"+".dp-py .magicmethods { color: #808080; }"+".dp-py .exceptions { color: brown; }"+".dp-py .types { color: brown; font-style: italic; }"+".dp-py .commonlibs { color: #8A2BE2; font-style: italic; }"};dp.sh.Brushes.Python.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Python.Aliases=["py","python"];dp.sh.Brushes.Ruby=function(){var $="alias and BEGIN begin break case class def define_method defined do each else elsif "+"END end ensure false for if in module new next nil not or raise redo rescue retry return "+"self super then throw true undef unless until when while yield",_="Array Bignum Binding Class Continuation Dir Exception FalseClass File::Stat File Fixnum Fload "+"Hash Integer IO MatchData Method Module NilClass Numeric Object Proc Range Regexp String Struct::TMS Symbol "+"ThreadGroup Thread Time TrueClass";this.regexList=[{regex:dp.sh.RegexLib.SingleLinePerlComments,css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp(":[a-z][A-Za-z0-9_]*","g"),css:"symbol"},{regex:new RegExp("(\\$|@@|@)\\w+","g"),css:"variable"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"},{regex:new RegExp(this.GetKeywords(_),"gm"),css:"builtin"}];this.CssClass="dp-rb";this.Style=".dp-rb .symbol { color: #a70; }"+".dp-rb .variable { color: #a70; font-weight: bold; }"};dp.sh.Brushes.Ruby.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Ruby.Aliases=["ruby","rails","ror"];dp.sh.Brushes.Sql=function(){var _="abs avg case cast coalesce convert count current_timestamp "+"current_user day isnull left lower month nullif replace right "+"session_user space substring sum system_user upper user year",$="absolute action add after alter as asc at authorization begin bigint "+"binary bit by cascade char character check checkpoint close collate "+"column commit committed connect connection constraint contains continue "+"create cube current current_date current_time cursor database date "+"deallocate dec decimal declare default delete desc distinct double drop "+"dynamic else end end-exec escape except exec execute false fetch first "+"float for force foreign forward free from full function global goto grant "+"group grouping having hour ignore index inner insensitive insert instead "+"int integer intersect into is isolation key last level load local max min "+"minute modify move name national nchar next no numeric of off on only "+"open option order out output partial password precision prepare primary "+"prior privileges procedure public read real references relative repeatable "+"restrict return returns revoke rollback rollup rows rule schema scroll "+"second section select sequence serializable set size smallint static "+"statistics table temp temporary then time timestamp to top transaction "+"translation trigger true truncate uncommitted union unique update values "+"varchar varying view when where with work",A="all and any between cross in join like not null or outer some";this.regexList=[{regex:new RegExp("--(.*)$","gm"),css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:dp.sh.RegexLib.SingleQuotedString,css:"string"},{regex:new RegExp(this.GetKeywords(_),"gmi"),css:"func"},{regex:new RegExp(this.GetKeywords(A),"gmi"),css:"op"},{regex:new RegExp(this.GetKeywords($),"gmi"),css:"keyword"}];this.CssClass="dp-sql";this.Style=".dp-sql .func { color: #ff1493; }"+".dp-sql .op { color: #808080; }"};dp.sh.Brushes.Sql.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Sql.Aliases=["sql"];dp.sh.Brushes.Vb=function(){var $="AddHandler AddressOf AndAlso Alias And Ansi As Assembly Auto "+"Boolean ByRef Byte ByVal Call Case Catch CBool CByte CChar CDate "+"CDec CDbl Char CInt Class CLng CObj Const CShort CSng CStr CType "+"Date Decimal Declare Default Delegate Dim DirectCast Do Double Each "+"Else ElseIf End Enum Erase Error Event Exit False Finally For Friend "+"Function Get GetType GoSub GoTo Handles If Implements Imports In "+"Inherits Integer Interface Is Let Lib Like Long Loop Me Mod Module "+"MustInherit MustOverride MyBase MyClass Namespace New Next Not Nothing "+"NotInheritable NotOverridable Object On Option Optional Or OrElse "+"Overloads Overridable Overrides ParamArray Preserve Private Property "+"Protected Public RaiseEvent ReadOnly ReDim REM RemoveHandler Resume "+"Return Select Set Shadows Shared Short Single Static Step Stop String "+"Structure Sub SyncLock Then Throw To True Try TypeOf Unicode Until "+"Variant When While With WithEvents WriteOnly Xor";this.regexList=[{regex:new RegExp("'.*$","gm"),css:"comment"},{regex:dp.sh.RegexLib.DoubleQuotedString,css:"string"},{regex:new RegExp("^\\s*#.*","gm"),css:"preprocessor"},{regex:new RegExp(this.GetKeywords($),"gm"),css:"keyword"}];this.CssClass="dp-vb"};dp.sh.Brushes.Vb.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Vb.Aliases=["vb","vb.net"];dp.sh.Brushes.Xml=function(){this.CssClass="dp-xml";this.Style=".dp-xml .cdata { color: #ff1493; }"+".dp-xml .tag, .dp-xml .tag-name { color: #069; font-weight: bold; }"+".dp-xml .attribute { color: red; }"+".dp-xml .attribute-value { color: blue; }"};dp.sh.Brushes.Xml.prototype=new dp.sh.Highlighter();dp.sh.Brushes.Xml.Aliases=["xml","xhtml","xslt","html","xhtml"];dp.sh.Brushes.Xml.prototype.ProcessRegexList=function(){function B(_,$){_[_.length]=$}var $=0,A=null,_=null;this.GetMatches(new RegExp("(<|<)\\!\\[[\\w\\s]*?\\[(.|\\s)*?\\]\\](>|>)","gm"),"cdata");this.GetMatches(new RegExp("(<|<)!--\\s*.*?\\s*--(>|>)","gm"),"comments");_=new RegExp("([:\\w-.]+)\\s*=\\s*(\".*?\"|'.*?'|\\w+)*|(\\w+)","gm");while((A=_.exec(this.code))!=null){if(A[1]==null)continue;B(this.matches,new dp.sh.Match(A[1],A.index,"attribute"));if(A[2]!=undefined)B(this.matches,new dp.sh.Match(A[2],A.index+A[0].indexOf(A[2]),"attribute-value"))}this.GetMatches(new RegExp("(<|<)/*\\?*(?!\\!)|/*\\?*(>|>)","gm"),"tag");_=new RegExp("(?:<|<)/*\\?*\\s*([:\\w-.]+)","gm");while((A=_.exec(this.code))!=null)B(this.matches,new dp.sh.Match(A[1],A.index+A[0].indexOf(A[1]),"tag-name"))}
//}}}
<<myComment>>
Comment of: [[SyntaxHighlighterPlugin]]
----
~~:::::__Sat Jun 26 2010 17:58:53 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Changed: alert("The code is in your clipboard now") TO use displayMessage();
/***
StyleSheet for ~SyntaxHighlighter
***/
/*{{{*/
.dp-highlighter
{
font-family: "Consolas", "Courier New", Courier, mono, serif;
font-size: 12px;
background-color: #E7E5DC;
width: 99%;
overflow: auto;
margin: 18px 0 18px 0 !important;
padding-top: 1px; /* adds a little border on top when controls are hidden */
}
/* clear styles */
.dp-highlighter ol,
.dp-highlighter ol li,
.dp-highlighter ol li span
{
margin: 0;
padding: 0;
border: none;
}
.dp-highlighter a,
.dp-highlighter a:hover
{
background: none;
border: none;
padding: 0;
margin: 0;
}
.dp-highlighter .bar
{
padding-left: 45px;
}
.dp-highlighter.collapsed .bar,
.dp-highlighter.nogutter .bar
{
padding-left: 0px;
}
.dp-highlighter ol
{
list-style: decimal; /* for ie */
background-color: #fff;
margin: 0px 0px 1px 45px !important; /* 1px bottom margin seems to fix occasional Firefox scrolling */
padding: 0px;
color: #5C5C5C;
}
.dp-highlighter.nogutter ol,
.dp-highlighter.nogutter ol li
{
list-style: none !important;
margin-left: 0px !important;
}
.dp-highlighter ol li,
.dp-highlighter .columns div
{
list-style: decimal-leading-zero; /* better look for others, override cascade from OL */
list-style-position: outside !important;
border-left: 3px solid #6CE26C;
background-color: #F8F8F8;
color: #5C5C5C;
padding: 0 3px 0 10px !important;
margin: 0 !important;
line-height: 14px;
}
.dp-highlighter.nogutter ol li,
.dp-highlighter.nogutter .columns div
{
border: 0;
}
.dp-highlighter .columns
{
background-color: #F8F8F8;
color: gray;
overflow: hidden;
width: 100%;
}
.dp-highlighter .columns div
{
padding-bottom: 5px;
}
.dp-highlighter ol li.alt
{
background-color: #FFF;
color: inherit;
}
.dp-highlighter ol li span
{
color: black;
background-color: inherit;
}
/* Adjust some properties when collapsed */
.dp-highlighter.collapsed ol
{
margin: 0px;
}
.dp-highlighter.collapsed ol li
{
display: none;
}
/* Additional modifications when in print-view */
.dp-highlighter.printing
{
border: none;
}
.dp-highlighter.printing .tools
{
display: none !important;
}
.dp-highlighter.printing li
{
display: list-item !important;
}
/* Styles for the tools */
.dp-highlighter .tools
{
padding: 3px 8px 3px 10px;
font: 9px Verdana, Geneva, Arial, Helvetica, sans-serif;
color: silver;
background-color: #f8f8f8;
padding-bottom: 10px;
border-left: 3px solid #6CE26C;
}
.dp-highlighter.nogutter .tools
{
border-left: 0;
}
.dp-highlighter.collapsed .tools
{
border-bottom: 0;
}
.dp-highlighter .tools a
{
font-size: 9px;
color: #a0a0a0;
background-color: inherit;
text-decoration: none;
margin-right: 10px;
}
.dp-highlighter .tools a:hover
{
color: red;
background-color: inherit;
text-decoration: underline;
}
/* About dialog styles */
.dp-about { background-color: #fff; color: #333; margin: 0px; padding: 0px; }
.dp-about table { width: 100%; height: 100%; font-size: 11px; font-family: Tahoma, Verdana, Arial, sans-serif !important; }
.dp-about td { padding: 10px; vertical-align: top; }
.dp-about .copy { border-bottom: 1px solid #ACA899; height: 95%; }
.dp-about .title { color: red; background-color: inherit; font-weight: bold; }
.dp-about .para { margin: 0 0 4px 0; }
.dp-about .footer { background-color: #ECEADB; color: #333; border-top: 1px solid #fff; text-align: right; }
.dp-about .close { font-size: 11px; font-family: Tahoma, Verdana, Arial, sans-serif !important; background-color: #ECEADB; color: #333; width: 60px; height: 22px; }
/* Language specific styles */
.dp-highlighter .comment, .dp-highlighter .comments { color: #008200; background-color: inherit; }
.dp-highlighter .string { color: blue; background-color: inherit; }
.dp-highlighter .keyword { color: #069; font-weight: bold; background-color: inherit; }
.dp-highlighter .preprocessor { color: gray; background-color: inherit; }
/*}}}*/
<<tabs txtTabIndex
Author 'By Author' TabAuthor
Mine 'Created by Me' TabMine
"Tags" "All tags" TabTags
All 'All tiddlers' TabAll>>
Created by me:
<<listByAuthor creator currentUser>>
Modified by me:
<<listByAuthor modifier currentUser>>
<<noTags>><<allTags excludeLists>>
/***
|''Name:''|TagEditPlugin|
|''Description:''|Edit tags quickly|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#TagEditPlugin|
|''Dependencies:''||
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|July 6, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Adds a button on the toolbar command to edit tags quickly.
!!Usage
#Import
#Save & Reload
#Add {{{tagEdit}}} to [[ToolbarCommands]] in the ~ViewToolbar slice.
!!Code
***/
//{{{
if(!version.extensions.TagEditPlugin) {
version.extensions.TagEditPlugin= {installed:true};
config.commands.tagEdit= {
text: "tags",
tooltip: "Edit Tags",
readOnlyText: "",
readOnlyTooltip: "",
handler: function(event,src,title) {
var tiddler=store.getTiddler(title);
var tags=String.encodeTiddlyLinkList(tiddler.tags);
var ans=prompt("Enter tag: ",tags);
tags = ans.readBracketedList();
tiddler.set(null,null,null,null,tags);
story.refreshTiddler(title,null,true);
return false;
},
};
} //# end of 'install only once'
//}}}
/***
|''Name:''|~TaggerPlugin|
|''Version:''|1.0.1 (2006-06-01)|
|''Source:''|http://tw.lewcid.org//#TaggerPlugin|
|''Author:''|SaqImtiaz|
|''Description:''|Provides a drop down listing current tiddler tags, and allowing toggling of tags.|
|''Documentation:''|[[TaggerPluginDocumentation]]|
|''Source Code:''|[[TaggerPluginSource]]|
|''~TiddlyWiki:''|Version 2.0.8 or better|
!Examples & Usage:
*At it's simplest, using tagger is as simple as {{{<<tagger>>}}} <<tagger>>
**This gives a dropdown with the current tiddler tags, followed by all the tags in the TW.
*You can also use a list of specified tags instead of all tags in the TW, by specifying a source tiddler.
**{{{<<tagger source:TagsDB>>}}} <<tagger source:TagDataBase>>
*You can also display ONLY the current tiddler tags
**{{{<<tagger taglist:false>>}}} <<tagger taglist:false>>
*To exclude tags from the list: {{{<<tagger exclude:"excludeLists Tag2 [[Tag with spaces]]">>}}} <<tagger exclude:"excludeLists Tag2 [[Tag with spaces]]">>
*For a custom button label: {{{<<tagger label:"custom label">>}}} <<tagger label:"custom label">>
*For a custom tooltip: {{{<<tagger tooltip:"custom tooltip">>}}} <<tagger tooltip:"custom tooltip">>
***/
//{{{
config.tagger={
defaults:{
label: 'Tags: ',
tooltip: 'Manage tiddler tags',
taglist: 'true',
excludeTags: '',
notags: 'tiddler has no tags',
aretags: 'current tiddler tags:',
toggletext: 'add tags:'
}
};
config.macros.tagger={};
config.macros.tagger.arrow = (document.all?"▼":"▾"); // the fat one is the only one that works in IE
config.macros.tagger.handler = function(place,macroName,params,wikifier,paramString,tiddler) {
var defaults = config.tagger.defaults;
var nAV = paramString.parseParams('tagman', null, true);
var label = ((nAV[0].label)&&(nAV[0].label[0])!='.')?nAV[0].label[0]+this.arrow: defaults.label+this.arrow;
var tooltip = ((nAV[0].tooltip)&&(nAV[0].tooltip[0])!='.')?nAV[0].tooltip[0]: defaults.tooltip;
var taglist = ((nAV[0].taglist)&&(nAV[0].taglist[0])!='.')?nAV[0].taglist[0]: defaults.taglist;
var exclude = ((nAV[0].exclude)&&(nAV[0].exclude[0])!='.')?(nAV[0].exclude[0]).readBracketedList(): defaults.excludeTags.readBracketedList();
if ((nAV[0].source)&&(nAV[0].source[0])!='.')var source = nAV[0].source[0];
if (source&&!store.getTiddler(source)) return false;
var onclick = function(e) {
if (!e) var e = window.event;
var popup = Popup.create(this);
var tagsarray = store.getTags();
var tags=new Array();
for (var i=0; i<tagsarray.length; i++){
tags.push(tagsarray[i][0]);}
if (source)
{var sourcetiddler=store.getTiddler(source);
tags=sourcetiddler.tags.sort();}
var currentTags = tiddler.tags.sort();
var createButtons=function(text,theTag,tooltipPrefix){
var sp = createTiddlyElement(createTiddlyElement(popup,"li"),"span",null,"tagger");
var theToggle = createTiddlyButton(sp,text,tooltipPrefix+" '"+theTag+"'",taggerOnToggle,"button","toggleButton");
theToggle.setAttribute("tiddler",tiddler.title);
theToggle.setAttribute("tag",theTag);
insertSpacer(sp);
if (window.createTagButton_orig_mptw)
createTagButton_orig_mptw(sp,theTag);
else
createTagButton(sp,theTag);
}
createTiddlyElement(popup,"li",null,"listTitle",(tiddler.tags.length == 0 ? defaults.notags : defaults.aretags));
for (var t=0; t<currentTags.length; t++){
createButtons("[x]",currentTags[t],"remove tag ");
}
createTiddlyElement(createTiddlyElement(popup,"li"),"hr");
if (taglist!='false')
{ createTiddlyElement(popup,"li",null,"listTitle",defaults.toggletext);
for (var i=0; i<tags.length; i++){
if (!tiddler.tags.contains(tags[i])&&!exclude.contains(tags[i]))
{createButtons("[ ]",tags[i],"add tag ");
}
}
createTiddlyElement(createTiddlyElement(popup,"li"),"hr");
}
var newTagButton = createTiddlyButton(createTiddlyElement(popup,"li"),("Create new tag"),null,taggerOnToggle);
newTagButton.setAttribute("tiddler",tiddler.title);
if (source) newTagButton.setAttribute("source",source);
Popup.show(popup,false);
e.cancelBubble = true;
if (e.stopPropagation) e.stopPropagation();
return(false);
};
createTiddlyButton(place,label,tooltip,onclick,"button","taggerDrpBtn");
};
window.taggerOnToggle = function(e) {
var tag = this.getAttribute("tag");
var title = this.getAttribute("tiddler");
var tiddler = store.getTiddler(title);
if (!tag)
{
var newtag=prompt("Enter new tag:","");
if (newtag!=''&&newtag!=null)
{
var tag=newtag;
if (this.getAttribute("source"))
{
var sourcetiddler = store.getTiddler(this.getAttribute("source"));
sourcetiddler.tags.pushUnique(newtag);}
}
else
{return false;};
}
if (!tiddler || !tiddler.tags)
{
store.saveTiddler(title,title,'',config.options.txtUserName,new Date(),tag);
}
else
{if (tiddler.tags.indexOf(tag)==-1)
{
tiddler.tags.push(tag);
}
else if(!newtag)
{
tiddler.tags.splice(tiddler.tags.indexOf(tag),1);
}
store.saveTiddler(tiddler.title,tiddler.title,tiddler.text,tiddler.modifier,tiddler.modified,tiddler.tags);
refreshPageTemplate();
};
story.refreshTiddler(title,null,true);
autoSaveChanges();
return false;
};
setStylesheet(
".tagger a.button {font-weight: bold;display:inline; padding:0px;}\n"+
".tagger #toggleButton {padding-left:2px; padding-right:2px; margin-right:1px; font-size:110%;}\n"+
"#nestedtagger {background:#2E5ADF; border: 1px solid #0331BF;}\n"+
".popup .listTitle {color:#000;}\n"+
"",
"TaggerStyles");
window.lewcidTiddlerSwapTag = function (tiddler, oldTag, newTag){
for (var i = 0; i < tiddler.tags.length; i++)
if (tiddler.tags[i] == oldTag) {
tiddler.tags[i] = newTag;
return true;}
return false;
}
window.lewcidRenameTag = function(e) {
var tag=this.getAttribute("tag");
var newtag=prompt("Rename tag '"+tag+"' to:",tag);
if ((newtag==tag)||(newtag==null)) {return false;}
if(store.tiddlerExists(newtag))
{if(confirm(config.messages.overwriteWarning.format([newtag.toString()])))
story.closeTiddler(newtag,false,false);
else
return null;}
tagged=store.getTaggedTiddlers(tag);
if (tagged.length!=0){
for (var j = 0; j < tagged.length; j++)
lewcidTiddlerSwapTag(tagged[j],tag,newtag);}
if (store.tiddlerExists(tag))
{store.saveTiddler(tag,newtag);}
if (document.getElementById("tiddler"+tag))
{var oldTagTiddler = document.getElementById(story.idPrefix + tag);
var before= story.positionTiddler(oldTagTiddler);
var place = document.getElementById(story.container);
story.closeTiddler(tag,false,false);
story.createTiddler(place,before,newtag,null);
story.saveTiddler(newtag);}
autoSaveChanges();
return false;
}
window.onClickTag=function(e)
{
if (!e) var e = window.event;
var theTarget = resolveTarget(e);
var nested = (!isNested(theTarget));
if ((Popup.stack.length > 1)&&(nested==true)) {Popup.removeFrom(1);}
else if(Popup.stack.length > 0 && nested==false) {Popup.removeFrom(0);};
var theId = (nested==false)? "popup" : "nestedtagger";
var popup = createTiddlyElement(document.body,"ol",theId,"popup",null);
Popup.stack.push({root: this, popup: popup});
var tag = this.getAttribute("tag");
var title = this.getAttribute("tiddler");
if(popup && tag)
{
var tagged = store.getTaggedTiddlers(tag);
var titles = [];
var li,r;
for(r=0;r<tagged.length;r++)
if(tagged[r].title != title)
titles.push(tagged[r].title);
var lingo = config.views.wikified.tag;
if(titles.length > 0)
{
var openAll = createTiddlyButton(createTiddlyElement(popup,"li"),lingo.openAllText.format([tag]),lingo.openAllTooltip,onClickTagOpenAll);
openAll.setAttribute("tag",tag);
createTiddlyElement(createTiddlyElement(popup,"li"),"hr");
for(r=0; r<titles.length; r++)
{
createTiddlyLink(createTiddlyElement(popup,"li"),titles[r],true);
}
}
else
createTiddlyText(createTiddlyElement(popup,"li",null,"disabled"),lingo.popupNone.format([tag]));
createTiddlyElement(createTiddlyElement(popup,"li"),"hr");
var h = createTiddlyLink(createTiddlyElement(popup,"li"),tag,false);
createTiddlyText(h,lingo.openTag.format([tag]));
createTiddlyElement(createTiddlyElement(popup,"li"),"hr");
var renameTagButton = createTiddlyButton(createTiddlyElement(popup,"li"),("Rename tag '"+tag+"'"),null,lewcidRenameTag);
renameTagButton.setAttribute("tag",tag)
}
Popup.show(popup,false);
e.cancelBubble = true;
if (e.stopPropagation) e.stopPropagation();
return(false);
}
if (!window.isNested)
window.isNested = function(e) {
while (e != null) {
var contentWrapper = document.getElementById("contentWrapper");
if (contentWrapper == e) return true;
e = e.parentNode;
}
return false;
};
//}}}
<<myComment>>
----
~~:::::__Fri Jun 25 2010 23:32:28 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ This plugin did not work w/ tw2.5 or above. I did changed a line to make it work. I changed tags.find() to tags.indexOf() in window.taggerOnToggle function.
* if (tiddler.tags.indexOf(tag)==-1);
* tiddler.tags.splice(tiddler.tags.indexOf(tag),1);
----
~~:::::__Sat Jun 26 2010 16:11:25 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ CHANGED: {{{if(config.options.chkAutoSave) saveChanges();}}}
TO: {{{autoSaveChanges();}}}
/***
|Name|TextAreaPlugin|
|Source|http://www.TiddlyTools.com/#TextAreaPlugin|
|Documentation|http://www.TiddlyTools.com/#TextAreaPluginInfo|
|Version|2.2.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|Adds Find/Again keyboard search, autosize, and 'stretch bar' resize for textarea controls|
!!!!!Documentation
>see [[TextAreaPluginInfo]]
!!!!!Configuration
<<<
<<option chkTextAreaExtensions>> use control-f (find), control-g (find again) inside text area
<<option chkDisableAutoSelect>> place cursor at start of textarea instead of pre-selecting content
<<option chkResizeEditor>> modify shadow EditTemplate to add resizeable text area (and autosize command)
<<<
!!!!!Revisions
<<<
2009.04.08 [2.2.1] added autosizeEditor macro to enable automatic autosizing without using toolbar command
2009.04.06 [2.2.0] added resizeListbox macro definition and adjusted dragbar width calculation.
|please see [[TextAreaPluginInfo]] for additional revision details|
2006.01.22 [1.0.0] Moved from temporary "System Tweaks" tiddler into 'real' TextAreaPlugin tiddler.
<<<
!!!!!Code
***/
//{{{
version.extensions.TextAreaPlugin= {major: 2, minor: 2, revision: 1, date: new Date(2009,4,8)};
if (config.options.chkTextAreaExtensions===undefined) config.options.chkTextAreaExtensions=true;
if (config.options.chkDisableAutoSelect===undefined) config.options.chkDisableAutoSelect=true;
if (config.options.chkResizeEditor===undefined) config.options.chkResizeEditor=true;
// automatically tweak shadow EditTemplate to add "autosizeEditor" toolbar command
if (config.options.chkResizeEditor)
config.shadowTiddlers.EditTemplate=config.shadowTiddlers.EditTemplate.replace(/deleteTiddler/,"deleteTiddler autosizeEditor");
// automatically tweak shadow EditTemplate to add "resizeEditor" macro
if (config.options.chkResizeEditor)
config.shadowTiddlers.EditTemplate+="<span macro='resizeEditor'></span>";
// Put focus in a specified tiddler field
Story.prototype.TextAreaExtensions_focusTiddler=Story.prototype.focusTiddler;
Story.prototype.focusTiddler = function(title,field)
{
this.TextAreaExtensions_focusTiddler.apply(this,arguments); // first call core
var e = this.getTiddlerField(title,field);
if (e && config.options.chkDisableAutoSelect) {
if (e.setSelectionRange) // FF
e.setSelectionRange(0,0);
else if (e.createTextRange) // IE
{ var r=e.createTextRange(); r.collapse(true); r.select(); }
}
if (e && config.options.chkTextAreaExtensions) addKeyDownHandlers(e);
}
//}}}
//{{{
function addKeyDownHandlers(e)
{
// exit if not textarea or element doesn't allow selections
if (e.tagName.toLowerCase()!="textarea"||!e.setSelectionRange||e.initialized) return;
// utility function: exits keydown handler and prevents browser from processing the keystroke
var processed=function(ev) {
ev.cancelBubble=true; // IE4+
try{event.keyCode=0;}catch(e){}; // IE5
if (window.event) ev.returnValue=false; // IE6
if (ev.preventDefault) ev.preventDefault(); // moz/opera/konqueror
if (ev.stopPropagation) ev.stopPropagation(); // all
return false;
}
// capture keydown in edit field
e.saved_onkeydown=e.onkeydown; // save current keydown handler (if any)
e.onkeydown=function(ev) { if (!ev) var ev=window.event;
var key=ev.keyCode;
if (!key) {
var char=event.which?event.which:event.charCode;
if (char==102) key=70;
if (char==103) key=71;
}
// process CTRL-F (find matching text) or CTRL-G (find next match)
if (ev.ctrlKey && (key==70||key==71)) {
// prompt for text to find
var defFind=e.findText?e.findText:e.value.substring(e.selectionStart,e.selectionEnd);
if (key==70||!e.findText||!e.findText.length) // ctrl-f or no saved search text
{ var f=prompt("find:", defFind); e.focus(); if (f) e.findText=f; }
if (!e.findText||!e.findText.length) return processed(ev); // if no search text, exit
// do case-insensitive match with 'wraparound'... if not found, alert and exit
var newstart=e.value.toLowerCase().indexOf(e.findText.toLowerCase(),e.selectionStart+1);
if (newstart==-1) newstart=e.value.toLowerCase().indexOf(e.findText.toLowerCase());
if (newstart==-1) { alert("'"+e.findText+"' not found"); e.focus(); return processed(ev); }
// set new selection, scroll it into view, and report line position in status bar
e.setSelectionRange(newstart,newstart+e.findText.length);
var linecount=e.value.split('\n').length;
var thisline=e.value.substr(0,e.selectionStart).split('\n').length;
e.scrollTop=Math.floor((thisline-1-e.rows/2)*e.scrollHeight/linecount);
window.status="line: "+thisline+"/"+linecount;
return processed(ev);
}
if (e.saved_onkeydown) // call previous keydown handler (if any)
e.saved_onkeydown(ev);
}
e.initialized=true;
}
//}}}
// // 'autosize' toolbar command
//{{{
config.commands.autosizeEditor = {
text: 'autosize',
tooltip: 'automatically adjust the editor height to fit the contents',
text_alt: '\u221Aautosize',
hideReadOnly: false,
handler: function(event,src,title) {
var here=story.findContainingTiddler(src); if (!here) return;
var ta=here.getElementsByTagName('textarea'); if (!ta) return;
for (i=0;i<ta.length;i++) {
// only autosize textareas actually used to edit tiddler fields
if (ta[i].getAttribute("edit")==undefined) continue;
ta[i].button=src;
if (!ta[i].maxed)
config.commands.autosizeEditor.on(ta[i]);
else
config.commands.autosizeEditor.off(ta[i],true);
}
return false;
},
on: function(e) {
if (e.maxed) return; // already autosizing!
if (e.savedheight==undefined)
e.savedheight=e.style.height;
if (e.savedkeyup==undefined) {
e.savedkeyup=e.onkeyup;
e.onkeyup=function(ev) {
if (!ev) var ev=window.event; var e=resolveTarget(ev);
e.style.height=e.scrollHeight+'px';
if (e.savedkeyup) e.savedkeyup();
}
}
// IE reports error: "not implemented" for onkeypress
if (!config.browser.isIE && e.savedkeypress==undefined) {
e.savedkeypress=e.onkeypress;
e.onkeypress=function(ev) {
if (!ev) var ev=window.event; var e=resolveTarget(ev);
if (ev.keyCode==33) { // PGUP
if (window.scrollByPages) window.scrollByPages(-1);
return false;
}
if (ev.keyCode==34) { // PGDN
if (window.scrollByPages) window.scrollByPages(1);
return false;
}
if (e.savedkeypress) e.savedkeypress();
}
}
e.style.height=e.scrollHeight+'px';
if (e.button) e.button.innerHTML=config.commands.autosizeEditor.text_alt;
e.maxed=true;
},
off: function(e,resetHeight) {
if (resetHeight) e.style.height=e.savedheight;
e.onkeyup=e.savedkeyup;
// IE reports error: "not implemented" for onkeypress
if (!config.browser.isIE) e.onkeypress=e.savedkeypress;
if (e.button) e.button.innerHTML=config.commands.autosizeEditor.text;
e.maxed=false;
}
};
config.macros.autosizeEditor={
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var here=story.findContainingTiddler(place); if (!here) return;
var ta=here.getElementsByTagName('textarea'); if (!ta) return;
for (i=0;i<ta.length;i++) {
// only autosize textareas actually used to edit tiddler fields
if (ta[i].getAttribute("edit")==undefined) continue;
config.commands.autosizeEditor.on(ta[i]);
}
return false;
}
}
//}}}
// // grab-and-stretch handle
//{{{
config.macros.resizeEditor = { // add stretch bar to editor textarea
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var here=story.findContainingTiddler(place); if (!here) return;
var ta=here.getElementsByTagName('textarea');
if (ta) for (i=0;i<ta.length;i++) {
// only resize tiddler editor textareas
if (ta[i].getAttribute("edit")==undefined) continue;
new window.TextAreaResizer(ta[i]);
}
}
}
config.macros.resizeTiddler = { // add stretch bar to tiddler viewer element
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var here=story.findContainingTiddler(place); if (!here) return;
var elems=here.getElementsByTagName('div');
if (elems) for (i=0;i<elems.length;i++) if (hasClass(elems[i],'viewer')) break;
if (i<elems.length) new window.TextAreaResizer(elems[i]);
}
}
config.macros.resizeFrame = { // add stretch bar to iframes
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var here=story.findContainingTiddler(place); if (!here) return;
var fr=here.getElementsByTagName('iframe');
if (fr) for (i=0;i<fr.length;i++) new window.TextAreaResizer(fr[i]);
}
}
config.macros.resizeListbox = { // add stretch bar to listbox controls
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var here=story.findContainingTiddler(place); if (!here) here=place;
var fr=here.getElementsByTagName('select');
if (fr) for (i=0;i<fr.length;i++) new window.TextAreaResizer(fr[i]);
}
}
// TextAreaResizer script by Jason Johnston (jj@lojjic.net)
// Created August 2003. Use freely, but give me credit.
// adds a handle below textareas that the user can drag with the mouse to resize the textarea.
// MODIFIED by ELS for use with TW
window.TextAreaResizer = function(elt) {
this.element = elt;
this.create();
}
window.TextAreaResizer.prototype = {
create : function() {
var elt = this.element;
var thisRef = this;
var h = this.handle = document.createElement("div");
h.style.height = "3px"; // was 4px... looked too fat!
h.style.overflow = "hidden"; // ELS: force IE to trim height to < 1em
var adjust=elt.nodeName=='textarea'?4:0; // 4 pixels for textarea border edge
// h.style.width=(elt.offsetWidth-adjust)+"px";
h.style.width="auto";
h.style.backgroundColor = "#999"; // ELS: standard mid-tone (dark) gray
h.style.cursor = "s-resize";
h.title = "Drag to resize text box";
h.onmousedown=function(evt){thisRef.dragStart(evt)};
elt.parentNode.insertBefore(h, elt.nextSibling);
},
dragStart : function(evt) {
if (!evt) var evt=window.event;
this.dragStop(evt); // ELS: stop any current drag processing first
var thisRef = this;
this.dragStartY = evt.clientY;
this.dragStartH = this.element.offsetHeight;
document.savedmousemove=document.onmousemove;
document.onmousemove=this.dragMoveHdlr=function(evt){thisRef.dragMove(evt)};
document.savedmouseup=document.onmouseup;
document.onmouseup=this.dragStopHdlr=function(evt){thisRef.dragStop(evt)};
},
dragMove : function(evt) {
if (!evt) var evt=window.event;
// ELS: make sure height is at least 10px
var h=this.dragStartH+evt.clientY-this.dragStartY;
if (h<10) h=10; this.element.style.height=h+"px";
// ELS: match handle to textarea width (which may have changed due to document scrollbars)
// var adjust=this.element.nodeName.toLowerCase()=='textarea'?4:0; // 4 pixels for textarea
// this.handle.style.width=(this.element.offsetWidth-adjust)+"px";
// ELS: when manually resizing, disable autoresizing (without restoring saved height)
if (this.element.maxed!=undefined && this.element.maxed)
config.commands.autosizeEditor.off(this.element,false);
},
dragStop : function(evt) {
if (!evt) var evt=window.event;
document.onmousemove=(document.savedmousemove!=undefined)?document.savedmousemove:null;
document.onmousemove=(document.savedmouseup!=undefined)?document.savedmouseup:null;
},
destroy : function() {
var elt = this.element;
elt.parentNode.removeChild(this.handle);
elt.style.height = "";
}
};
//}}}
/***
|''Name:''|TiddlersBarPlugin|
|''Description:''|A bar to switch between tiddlers through tabs (like browser tabs bar).|
|''Version:''|1.2.5|
|''Date:''|Jan 18,2008|
|''Source:''|http://visualtw.ouvaton.org/VisualTW.html|
|''Author:''|Pascal Collin|
|''License:''|[[BSD open source license|License]]|
|''~CoreVersion:''|2.1.0|
|''Browser:''|Firefox 2.0; InternetExplorer 6.0, others|
!Demos
On [[homepage|http://visualtw.ouvaton.org/VisualTW.html]], open several tiddlers to use the tabs bar.
!Installation
#import this tiddler from [[homepage|http://visualtw.ouvaton.org/VisualTW.html]] (tagged as systemConfig)
#save and reload
#''if you're using a custom [[PageTemplate]]'', add {{{<div id='tiddlersBar' refresh='none' ondblclick='config.macros.tiddlersBar.onTiddlersBarAction(event)'></div>}}} before {{{<div id='tiddlerDisplay'></div>}}}
#optionally, adjust StyleSheetTiddlersBar
!Tips
*Doubleclick on the tiddlers bar (where there is no tab) create a new tiddler.
*Tabs include a button to close {{{x}}} or save {{{!}}} their tiddler.
*By default, click on the current tab close all others tiddlers.
!Configuration options
<<option chkDisableTabsBar>> Disable the tabs bar (to print, by example).
<<option chkHideTabsBarWhenSingleTab >> Automatically hide the tabs bar when only one tiddler is displayed.
<<option txtSelectedTiddlerTabButton>> ''selected'' tab command button.
<<option txtPreviousTabKey>> previous tab access key.
<<option txtNextTabKey>> next tab access key.
!Code
***/
//{{{
config.options.chkDisableTabsBar = config.options.chkDisableTabsBar ? config.options.chkDisableTabsBar : false;
config.options.chkHideTabsBarWhenSingleTab = config.options.chkHideTabsBarWhenSingleTab ? config.options.chkHideTabsBarWhenSingleTab : false;
config.options.txtSelectedTiddlerTabButton = config.options.txtSelectedTiddlerTabButton ? config.options.txtSelectedTiddlerTabButton : "closeOthers";
config.options.txtPreviousTabKey = config.options.txtPreviousTabKey ? config.options.txtPreviousTabKey : "";
config.options.txtNextTabKey = config.options.txtNextTabKey ? config.options.txtNextTabKey : "";
config.macros.tiddlersBar = {
tooltip : "see ",
tooltipClose : "click here to close this tab",
tooltipSave : "click here to save this tab",
promptRename : "Enter tiddler new name",
currentTiddler : "",
previousState : false,
previousKey : config.options.txtPreviousTabKey,
nextKey : config.options.txtNextTabKey,
tabsAnimationSource : null, //use document.getElementById("tiddlerDisplay") if you need animation on tab switching.
handler: function(place,macroName,params) {
var previous = null;
if (config.macros.tiddlersBar.isShown())
story.forEachTiddler(function(title,e){
if (title==config.macros.tiddlersBar.currentTiddler){
var d = createTiddlyElement(null,"span",null,"tab tabSelected");
config.macros.tiddlersBar.createActiveTabButton(d,title);
if (previous && config.macros.tiddlersBar.previousKey) previous.setAttribute("accessKey",config.macros.tiddlersBar.nextKey);
previous = "active";
}
else {
var d = createTiddlyElement(place,"span",null,"tab tabUnselected");
var btn = createTiddlyButton(d,title,config.macros.tiddlersBar.tooltip + title,config.macros.tiddlersBar.onSelectTab);
btn.setAttribute("tiddler", title);
if (previous=="active" && config.macros.tiddlersBar.nextKey) btn.setAttribute("accessKey",config.macros.tiddlersBar.previousKey);
previous=btn;
}
var isDirty =story.isDirty(title);
var c = createTiddlyButton(d,isDirty ?"!":"x",isDirty?config.macros.tiddlersBar.tooltipSave:config.macros.tiddlersBar.tooltipClose, isDirty ? config.macros.tiddlersBar.onTabSave : config.macros.tiddlersBar.onTabClose,"tabButton");
c.setAttribute("tiddler", title);
if (place.childNodes) {
place.insertBefore(document.createTextNode(" "),place.firstChild); // to allow break line here when many tiddlers are open
place.insertBefore(d,place.firstChild);
}
else place.appendChild(d);
})
},
refresh: function(place,params){
removeChildren(place);
config.macros.tiddlersBar.handler(place,"tiddlersBar",params);
if (config.macros.tiddlersBar.previousState!=config.macros.tiddlersBar.isShown()) {
story.refreshAllTiddlers();
if (config.macros.tiddlersBar.previousState) story.forEachTiddler(function(t,e){e.style.display="";});
config.macros.tiddlersBar.previousState = !config.macros.tiddlersBar.previousState;
}
},
isShown : function(){
if (config.options.chkDisableTabsBar) return false;
if (!config.options.chkHideTabsBarWhenSingleTab) return true;
var cpt=0;
story.forEachTiddler(function(){cpt++});
return (cpt>1);
},
selectNextTab : function(){ //used when the current tab is closed (to select another tab)
var previous="";
story.forEachTiddler(function(title){
if (!config.macros.tiddlersBar.currentTiddler) {
story.displayTiddler(null,title);
return;
}
if (title==config.macros.tiddlersBar.currentTiddler) {
if (previous) {
story.displayTiddler(null,previous);
return;
}
else config.macros.tiddlersBar.currentTiddler=""; // so next tab will be selected
}
else previous=title;
});
},
onSelectTab : function(e){
var t = this.getAttribute("tiddler");
if (t) story.displayTiddler(null,t);
return false;
},
onTabClose : function(e){
var t = this.getAttribute("tiddler");
if (t) {
if(story.hasChanges(t) && !readOnly) {
if(!confirm(config.commands.cancelTiddler.warning.format([t])))
return false;
}
story.closeTiddler(t);
}
return false;
},
onTabSave : function(e) {
var t = this.getAttribute("tiddler");
if (!e) e=window.event;
if (t) config.commands.saveTiddler.handler(e,null,t);
return false;
},
onSelectedTabButtonClick : function(event,src,title) {
var t = this.getAttribute("tiddler");
if (!event) event=window.event;
if (t && config.options.txtSelectedTiddlerTabButton && config.commands[config.options.txtSelectedTiddlerTabButton])
config.commands[config.options.txtSelectedTiddlerTabButton].handler(event, src, t);
return false;
},
onTiddlersBarAction: function(event) {
var source = event.target ? event.target.id : event.srcElement.id; // FF uses target and IE uses srcElement;
if (source=="tiddlersBar") story.displayTiddler(null,'New Tiddler',DEFAULT_EDIT_TEMPLATE,false,null,null);
},
createActiveTabButton : function(place,title) {
if (config.options.txtSelectedTiddlerTabButton && config.commands[config.options.txtSelectedTiddlerTabButton]) {
var btn = createTiddlyButton(place, title, config.commands[config.options.txtSelectedTiddlerTabButton].tooltip ,config.macros.tiddlersBar.onSelectedTabButtonClick);
btn.setAttribute("tiddler", title);
}
else
createTiddlyText(place,title);
}
}
story.coreCloseTiddler = story.coreCloseTiddler? story.coreCloseTiddler : story.closeTiddler;
story.coreDisplayTiddler = story.coreDisplayTiddler ? story.coreDisplayTiddler : story.displayTiddler;
story.closeTiddler = function(title,animate,unused) {
if (title==config.macros.tiddlersBar.currentTiddler)
config.macros.tiddlersBar.selectNextTab();
story.coreCloseTiddler(title,false,unused); //disable animation to get it closed before calling tiddlersBar.refresh
var e=document.getElementById("tiddlersBar");
if (e) config.macros.tiddlersBar.refresh(e,null);
}
story.displayTiddler = function(srcElement,tiddler,template,animate,unused,customFields,toggle){
story.coreDisplayTiddler(config.macros.tiddlersBar.tabsAnimationSource,tiddler,template,animate,unused,customFields,toggle);
var title = (tiddler instanceof Tiddler)? tiddler.title : tiddler;
if (config.macros.tiddlersBar.isShown()) {
story.forEachTiddler(function(t,e){
if (t!=title) e.style.display="none";
else e.style.display="";
})
config.macros.tiddlersBar.currentTiddler=title;
}
var e=document.getElementById("tiddlersBar");
if (e) config.macros.tiddlersBar.refresh(e,null);
}
var coreRefreshPageTemplate = coreRefreshPageTemplate ? coreRefreshPageTemplate : refreshPageTemplate;
refreshPageTemplate = function(title) {
coreRefreshPageTemplate(title);
if (config.macros.tiddlersBar) config.macros.tiddlersBar.refresh(document.getElementById("tiddlersBar"));
}
ensureVisible=function (e) {return 0} //disable bottom scrolling (not useful now)
config.shadowTiddlers.StyleSheetTiddlersBar = "/*{{{*/\n";
config.shadowTiddlers.StyleSheetTiddlersBar += "#tiddlersBar .button {border:0}\n";
config.shadowTiddlers.StyleSheetTiddlersBar += "#tiddlersBar .tab {white-space:nowrap}\n";
config.shadowTiddlers.StyleSheetTiddlersBar += "#tiddlersBar {padding : 1em 0.5em 2px 0.5em}\n";
config.shadowTiddlers.StyleSheetTiddlersBar += ".tabUnselected .tabButton, .tabSelected .tabButton {padding : 0 2px 0 2px; margin: 0 0 0 4px;}\n";
config.shadowTiddlers.StyleSheetTiddlersBar += ".tiddler, .tabContents {border:1px [[ColorPalette::TertiaryPale]] solid;}\n";
config.shadowTiddlers.StyleSheetTiddlersBar +="/*}}}*/";
store.addNotification("StyleSheetTiddlersBar", refreshStyles);
config.refreshers.none = function(){return true;}
config.shadowTiddlers.PageTemplate=config.shadowTiddlers.PageTemplate.replace(/<div id='tiddlerDisplay'><\/div>/m,"<div id='tiddlersBar' refresh='none' ondblclick='config.macros.tiddlersBar.onTiddlersBarAction(event)'></div>\n<div id='tiddlerDisplay'></div>");
//}}}
if (config.tasks) { // for TW2.2b or above
config.tasks.uploadTask = {
text: "upload",
tooltip: "upload this tiddlywiki",
content: "<<tiddler TspotSidebar>>"
}
config.backstageTasks.push("uploadTask");
}
!!To get a tiddler's title
{{{title = this.getAttribute("title"); }}}
or
{{{story.findContainingTiddler(place).getAttribute("tiddler");}}}
{{{story.findContainingTiddler(this).getAttribute("tiddler");}}}
!!Setting tags
{{{ if (tiddler.tags.contains( "systemConfig" )) }}}
{{{ store.setTiddlerTag( title,1,"systemConfigDisable" ); }}}
!!Method overriding in js
{{{
cooltool.comment.orig_deleteTiddlerHandler = config.commands.deleteTiddler.handler;
config.commands.deleteTiddler.handler = function(event,src,title) {
alert("del");
return cooltool.comment.orig_deleteTiddlerHandler.apply(this,arguments);
};
}}}
!!Template Const
*DEFAULT_VIEW_TEMPLATE
*DEFAULT_EDIT_TEMPLATE
!!Install once version
{{{
if(!version.extensions.wordCount) {
version.extensions.wordCount= {installed:true};
//CODE HERE
};
}}}
!!Namespace
if(!window.cooltool) window.cooltool={};
if(!cooltool.XXXXXXX) cooltool.XXXXXXXX={};
!!Encode/Parsing tags
{{{ "string".readBracketedList(); }}}
{{{String.encodeTiddlyLink(tiddler.tags);}}}
{{{String.encodeTiddlyLinkList(tiddler.tags);}}}
!!Set dirty
{{{store.dirty=true;}}}
{{{store.setDirty(true);}}}
!!Autosave Chk
{{{autoSaveChanges();}}}
{{{if(config.options.chkAutoSave) saveChanges();}}}
!!Set style sheet
setStylesheet(strCSS,strDOM_ID);
!!create shadow tiddlers
config.shadowTiddlers.NAME="CODE";
config.commands.timeStamp = {
text: "time stamp",
tooltip: "Adds a timestamp",
handler: function(event,src,title) {
store.getTiddler(title).text += new Date();
story.refreshTiddler(title,null,true);
return false;
},
};
http://soloport.tiddlyspot.com/#CustomizationsPlugin
/*{{{*/
function getMessageDiv() {
var msgArea = document.getElementById("messageArea");
if (!msgArea)
return null;
// "close" link code was here (JOS) //
msgArea.style.display = "block";
setTimeout("clearMessage();",5000); // ms (JOS)
return createTiddlyElement(msgArea,"div");
}
/*}}}*/
<<tiddler QuickLog with: "To Do List" worklog '' '' ''>>
!
TODO:
#rewire sync-out to export plugin
#make a view collapse lock.
#yyencode & compression for file attach
#cron - backup, export,
#fix linkprogram
#add savelist to eval()
#char freq counter
#insert symbol btn
#fix edit sect plugin
----
if tab plugin is on, don't use rearrange and collapse plugin.
if(!chkDisableTabsBar){ // allow rearrange&collapse
}
----
/***
|Name|ToggleSideBarMacro|
|Created by|SaqImtiaz|
|Location|http://tw.lewcid.org/#ToggleSideBarMacro|
|Version|1.0|
|Requires|~TW2.x|
!Description:
Provides a button for toggling visibility of the SideBar. You can choose whether the SideBar should initially be hidden or displayed.
!Demo
<<toggleSideBar "Toggle Sidebar">>
!Usage:
{{{<<toggleSideBar>>}}} <<toggleSideBar>>
additional options:
{{{<<toggleSideBar label tooltip show/hide>>}}} where:
label = custom label for the button,
tooltip = custom tooltip for the button,
show/hide = use one or the other, determines whether the sidebar is shown at first or not.
(default is to show the sidebar)
You can add it to your tiddler toolbar, your MainMenu, or where you like really.
If you are using a horizontal MainMenu and want the button to be right aligned, put the following in your StyleSheet:
{{{ .HideSideBarButton {float:right;} }}}
!History
*23-07-06: version 1.0: completely rewritten, now works with custom stylesheets too, and easier to customize start behaviour.
*20-07-06: version 0.11
*27-04-06: version 0.1: working.
!Code
***/
//{{{
config.macros.toggleSideBar={};
config.macros.toggleSideBar.settings={
styleHide : "#sidebarOptions, #sidebarTabs {display:none;}\n"+"#contentWrapper #displayArea { margin-right: 1em;}\n"+"",
styleShow : " ",
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]&¶ms[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;
}
setStylesheet(".HideSideBarButton .button {font-weight:bold; padding: 0 5px;}\n","ToggleSideBarButtonStyles");
//}}}
|~ViewToolbar|closeTiddler closeOthers deleteTiddler myComment > +editTiddler wordCount basicCopy readOnlyTiddler fields syncing permalink references exportTiddler timeStamp renameTiddler tagEdit jump collapseOthers|
|~EditToolbar|saveTiddler -cancelTiddler deleteTiddler|
/***
|''Name:''|TrashPlugin|
|''Description:''|Trash bin for ~TikiWiki|
|''Version:''|1.1.1 (June 28, 2010) |
|''Source:''|http://cooltool.tiddlyspot.com/#TrashPlugin|
|''Author:''|Ido Magal, Kenny Z|
|''Licence:''|[[BSD open source license]]|
|''CoreVersion:''|2.6|
|''Browser:''|??|
!!Description
This plugin provides trash bin functionality. Instead of being permanently removed, deleted tiddlers are tagged with "Trash."
*Empty the trash by clicking on the <<emptyTrash>> button in the [[Trash]] tiddler.
*To restore a tiddler, click the "restore" command on the toolbar.
*Shortcuts:
**Holding down CTRL while clicking on "delete" or "restore" will bypass the trash bin.
**Holding down ALT while clicking on "delete" or "restore" will bring up [[Trash]].
!!Configuration
/%--<<option chkAutoEmptyTrashbin>> Automatically Empty Trash?--
Retain trash in trashbin for <<option txtDaysToKeepInTrashbin>> days. //0 to retain all.// %/
New trash are tagged as: <<option txtTrashTags>>
!!!Installation instructions
#Import
#Save and reload your wiki.
!!!Uninstallation instructions
#Empty the [[Trash]] ( <<emptyTrash>> )
#Delete this tiddler.
!!!Revision history
* V1.1.1 (June 28, 2010) added restore functionality, isolated trash by rename.
!!!To Do
* Make trash keep only n days worth of garbage.
!!Code
***/
//{{{
if(!version.extensions.TrashPlugin) {
version.extensions.TrashPlugin = {installed:true};
//if(!config.options.chkAutoEmptyTrashbin) config.options.chkAutoEmptyTrashbin = false;
if(!config.options.txtTrashKeepDays) config.options.txtDaysToKeepInTrashbin = 0;
if(!config.options.txtTrashTags)
config.options.txtTrashTags = "excludeLists excludeMissing excludeSearch";
config.macros.emptyTrash = {
label: "empty trash",
tooltip: "Delete items tagged as %0 that are older than %1 days old",
handler: function(place,macroName,params,wikifier,paramString,tiddler){
var namedParams = (paramString.parseParams(daysOld))[0];
var daysOld = namedParams['daysOld'] ? namedParams['daysOld'][0] : 0; // default
var buttonTitle = namedParams['title'] ? namedParams['title'][0] : this.label;
createTiddlyButton(place,buttonTitle,this.tooltip.format([cooltool.trashBin.tag,daysOld]),
cooltool.trashBin.emptyTrash(daysOld));
return false;
},
};
if(!window.cooltool) window.cooltool={};
if(!cooltool.trashBin) cooltool.trashBin={};
cooltool.trashBin = {
tag: "Trash",
movedMsg: "'%0' sent to trash bin",
emptyMsg: "The trash bin is empty.",
restoredMsg: "'%0' restored.",
noneToDelMsg: "There are no items in the trash older than %0 days.",
confirmMsg: "The following tiddlers will be deleted:\n\n'%0'\n\nIs it OK to proceed?",
deletedMsg: "Deleted '%0', ",
makeTrashBinMsg: "Trash bin created.",
emptyTrash: function(daysOld){
return function()
{
//daysOld = daysOld || config.options.txtDaysToKeepInTrashbin;
var statusMsg = '';
var collected = [];
var compareDate = new Date();
compareDate.setDate(compareDate.getDate()-daysOld);
store.forEachTiddler(function(title,tiddler){
if (tiddler.tags.contains(cooltool.trashBin.tag)
&& tiddler.modified < compareDate )
{ collected.push(title); }
});
if ( collected.length == 0 ){
if(daysOld==0) statusMsg=(cooltool.trashBin.emptyMsg);
else statusMsg=(cooltool.trashBin.emptyMsg.format( [daysOld] ) );
}
else{ // if trash to del
if (confirm(cooltool.trashBin.confirmMsg.format([collected.join("', '")])))
{
for(var i=0;i<collected.length;i++){ // remove -------------------------------------
story.closeTiddler(collected[i],false,false);
store.removeTiddler(collected[i]);
statusMsg+=(cooltool.trashBin.deletedMsg.format([collected[i]]));
} // ^^^couldn't get DM to NL nor <br />
store.setDirty( true );
}
}
cooltool.trashBin.removeTrashBin(); // remove Trash tiddler if no trash remains
displayMessage(statusMsg);
}
},
createTrashBin: function(){
if (!store.tiddlerExists(this.tag)){
store.saveTiddler(this.tag,this.tag,"<<emptyTrash>>","TrashPlugin",new Date());
return(cooltool.trashBin.makeTrashBinMsg);
}
},
removeTrashBin: function(){
if(store.getTaggedTiddlers(this.tag).length==0){
story.closeTiddler(this.tag,true,false);
store.removeTiddler(this.tag);
store.setDirty( true );
}else
story.refreshTiddler(this.tag,false,true );
},
banishTrash: function(tiddler,title){
// STORE THE Original Tags and info as fields
store.setValue(tiddler,"trash.tags",String.encodeTiddlyLinkList(tiddler.tags));
store.setValue(tiddler,"trash.title",tiddler.title);
store.setValue(tiddler,"trash.modifier",tiddler.modifier);
store.setValue(tiddler,"trash.modified",tiddler.modified.getTime());
// CHANGE THE MODIFIED DATE AND TAGS
var when = new Date();
var newTitle = title + "_Trash("+when.getTime()+")"
var tags=config.options.txtTrashTags+" [["+this.tag+"]]".readBracketedList();
//save tiddler w/ new title, tags, etc... and notify/setDirty.
store.deleteTiddler(title);
tiddler.set(newTitle,null,config.options.txtUserName,when,tags);
store.addTiddler(tiddler); store.notify(title,true); store.notify(newTitle,true);
store.dirty=true; store.setDirty(title,true); autoSaveChanges();
return cooltool.trashBin.movedMsg.format([title]);
},
restoreTrash: function(tiddler,title){
// Restore the original Tags and info
var oldTitle=store.getValue(tiddler,"trash.title");
var who=store.getValue(tiddler,"trash.modifier");
var tags=store.getValue(tiddler,"trash.tags").readBracketedList();
var when = new Date(parseInt(store.getValue(tiddler,"trash.modified")));
// ERROR CHECKING HERE
if(store.tiddlerExists(oldTitle)){
if(!confirm(oldTitle+" already exists, overwrite it?"))
return "Error: Tiddler already exists";
cooltool.trashBin.banishTrash(store.fetchTiddler(oldTitle),oldTitle);
}
// as of now, if any value is undefined or error, it will halt here w/o err msgs.
// Clear fields
delete tiddler.fields['trash.title'];
delete tiddler.fields['trash.tags'];
delete tiddler.fields['trash.modifier'];
delete tiddler.fields['trash.modified'];
//save tiddler w/ new title, tags, etc... and notify/setDirty.
store.deleteTiddler(title);
tiddler.set(oldTitle,null,who,when,tags);
store.addTiddler(tiddler); store.notify(title,true); store.notify(oldTitle,true);
store.dirty=true; store.setDirty(title,true); autoSaveChanges();
story.displayTiddler(null,oldTitle);
return cooltool.trashBin.restoredMsg.format([oldTitle]);
},
}
config.commands.restoreTiddler ={
text: "restore",
tooltip: "Restore this tiddler from trash bin",
handler: function( event,src,title ){
config.commands.deleteTiddler.handler(event,src,title);
},
};
////////////////// hijack delete command
cooltool.trashBin.disposeTiddler=config.commands.deleteTiddler.handler;
config.commands.deleteTiddler.handler = function( event,src,title ){
var tag = cooltool.trashBin.tag;
if(event.altKey){ // Display trash bin on alt click
if(store.tiddlerExists(tag))story.displayTiddler(null,tag);
else alert(cooltool.trashBin.emptyMsg);
} // if tiddler exists (i.e., not a NEW, unsaved tiddler in edit mode) and not bypassing Trash (holding CTRL key)
else if(store.tiddlerExists(title) && !event.ctrlKey){
// if Trashbin doesn't exist, create it and they will come...
cooltool.trashBin.createTrashBin();
var tiddler=store.fetchTiddler(title);
story.closeTiddler(title,true,event.shiftKey); // closing first is better.
if(!tiddler.tags.contains(tag)){ // if not trash BANISH, else RESTORE
statusMsg=cooltool.trashBin.banishTrash(tiddler,title);
}else{ // restore
statusMsg=cooltool.trashBin.restoreTrash(tiddler,title);
}
displayMessage(statusMsg);
}else {
cooltool.trashBin.disposeTiddler.apply(this,arguments)
}
story.refreshTiddler(tag,null,true);
return false;
};
//Hijacked getTemplateForTiddler
cooltool.trashBin.ori_getTemplate = Story.prototype.getTemplateForTiddler;
Story.prototype.getTemplateForTiddler=function(title,template,tiddler){
var t=cooltool.trashBin.ori_getTemplate(title,template,tiddler);
if(tiddler.tags.contains(cooltool.trashBin.tag)){
t=t.replace(/(deleteTiddler)/g,"restoreTiddler");
}
return t;
};
} //# end of 'install only once'
//}}}
<<myComment>>
Comment of: [[TrashPlugin]]
----
~~:::::__Sun Jun 27 2010 23:49:25 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Had a tiddler with alert() on and when being sent to Trash, the page refreshed each time a tag is set. Also an alert pops up each time its refreshed. Code changed to close the tiddler first before changing tags. Saw a significant improvement in speed.
----
~~:::::__Mon Jun 28 2010 02:04:42 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^
Made modifications the deleteTiddler.handler function:
*original data kept in fields
*tiddler given new info, so its isolated from TW
*modifier is "Trash" (puuuhaaha...)
*modified is trashed date.
----
~~:::::__Mon Jun 28 2010 15:41:51 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Changes:
*moved most functions to the cooltool namespace.
*added restore runctionality.
If alt+delete, brings up trash bin.
If viewing trash, delete command will change to restore command. But ctrl+del will still del it.
----
~~:::::__Tue Jun 29 2010 18:26:06 GMT-0400 (Eastern Daylight Time)__:::::~~
^^(__KennyZ Wrote:__)^^ Added safety when restoring tiddler with existing title.
/***
Description: Contains the stuff you need to use Tiddlyspot
Note, you also need UploadPlugin, PasswordOptionPlugin and LoadRemoteFileThroughProxy
from http://tiddlywiki.bidix.info for a complete working Tiddlyspot site.
***/
//{{{
// edit this if you are migrating sites or retrofitting an existing TW
config.tiddlyspotSiteId = 'cooltool';
// make it so you can by default see edit controls via http
config.options.chkHttpReadOnly = false;
window.readOnly = false; // make sure of it (for tw 2.2)
window.showBackstage = true; // show backstage too
// disable autosave in d3
if (window.location.protocol != "file:")
config.options.chkGTDLazyAutoSave = false;
// tweak shadow tiddlers to add upload button, password entry box etc
with (config.shadowTiddlers) {
SiteUrl = 'http://'+config.tiddlyspotSiteId+'.tiddlyspot.com';
SideBarOptions = SideBarOptions.replace(/(<<saveChanges>>)/,"$1<<tiddler TspotSidebar>>");
OptionsPanel = OptionsPanel.replace(/^/,"<<tiddler TspotOptions>>");
}
// create some shadow tiddler content
merge(config.shadowTiddlers,{
'TspotOptions':[
"tiddlyspot password:",
"<<option pasUploadPassword>>",
""
].join("\n"),
'TspotControls':[
"| tiddlyspot password:|<<option pasUploadPassword>>|",
"| site management:|<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . . " + config.tiddlyspotSiteId + ">>//(requires tiddlyspot password)//<br>[[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]], [[download (go offline)|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download]]|",
"| links:|[[tiddlyspot.com|http://tiddlyspot.com/]], [[FAQs|http://faq.tiddlyspot.com/]], [[blog|http://tiddlyspot.blogspot.com/]], email [[support|mailto:support@tiddlyspot.com]] & [[feedback|mailto:feedback@tiddlyspot.com]], [[donate|http://tiddlyspot.com/?page=donate]]|"
].join("\n"),
'WelcomeToTiddlyspot':[
"This document is a ~TiddlyWiki from tiddlyspot.com. A ~TiddlyWiki is an electronic notebook that is great for managing todo lists, personal information, and all sorts of things.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //What now?// @@ Before you can save any changes, you need to enter your password in the form below. Then configure privacy and other site settings at your [[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]] (your control panel username is //" + config.tiddlyspotSiteId + "//).",
"<<tiddler TspotControls>>",
"See also GettingStarted.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Working online// @@ You can edit this ~TiddlyWiki right now, and save your changes using the \"save to web\" button in the column on the right.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Working offline// @@ A fully functioning copy of this ~TiddlyWiki can be saved onto your hard drive or USB stick. You can make changes and save them locally without being connected to the Internet. When you're ready to sync up again, just click \"upload\" and your ~TiddlyWiki will be saved back to tiddlyspot.com.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Help!// @@ Find out more about ~TiddlyWiki at [[TiddlyWiki.com|http://tiddlywiki.com]]. Also visit [[TiddlyWiki.org|http://tiddlywiki.org]] for documentation on learning and using ~TiddlyWiki. New users are especially welcome on the [[TiddlyWiki mailing list|http://groups.google.com/group/TiddlyWiki]], which is an excellent place to ask questions and get help. If you have a tiddlyspot related problem email [[tiddlyspot support|mailto:support@tiddlyspot.com]].",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Enjoy :)// @@ We hope you like using your tiddlyspot.com site. Please email [[feedback@tiddlyspot.com|mailto:feedback@tiddlyspot.com]] with any comments or suggestions."
].join("\n"),
'TspotSidebar':[
"<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . . " + config.tiddlyspotSiteId + ">><html><a href='http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download' class='button'>download</a></html>"
].join("\n")
});
//}}}
tiddlyspot password:
<<option pasUploadPassword>>
<<upload http://cooltool.tiddlyspot.com/store.cgi index.html . . cooltool>><html><a href='http://cooltool.tiddlyspot.com/download' class='button'>download</a></html>
/***
<<<
|Name|UndoChangeBySyncPlugin|
|Source|http://cooltool.tiddlyspot.com#UndoChangeBySyncPlugin|
|Documentation||
|Version|0.01|
|Author|Kenny Z|
|License|Plubic Domain|
|~CoreVersion|2.6|
|Type|plugin|
|Description|Always download server version while synchronizing|
<<<
!Usage:
#Import
#Save and reload
!Code:
***/
//{{{
FileAdaptor.prototype.putTiddler = function(tiddler,context,userParams,callback){
callback= function(context,syncItem) {
if(syncItem) {
var msg= {text: "Overwrote local version", display:null, className:'gotFromServer'}
var tiddler = context.tiddler;
store.saveTiddler(tiddler.title,tiddler.title,tiddler.text,tiddler.modifier,tiddler.modified,tiddler.tags,tiddler.fields,true,tiddler.created);
syncItem.syncStatus = msg;
config.macros.sync.updateSyncStatus(syncItem);
}
};
return userParams.adaptor.getTiddler(tiddler.title,context,userParams,callback);
};
//}}}
| 22/06/2010 18:48:41 | YourName | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . |
| 28/06/2010 23:14:57 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 29/06/2010 16:39:34 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html#]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 29/06/2010 16:40:04 | YourName | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html#]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 29/06/2010 18:44:55 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 29/06/2010 18:49:53 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 29/06/2010 19:44:02 | YourName | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 29/06/2010 19:50:30 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 04/07/2010 17:59:04 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html#HistoryPluginRequired.zip]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 05/07/2010 00:52:16 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . | ok |
| 12/07/2010 19:22:55 | KennyZ | [[cooltool.html|file:///S:/APPZ/TiddlyWiki/cooltool.html]] | [[store.cgi|http://cooltool.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cooltool.tiddlyspot.com/index.html]] | . |
/***
|''Name:''|UploadPlugin|
|''Description:''|Save to web a TiddlyWiki|
|''Version:''|4.1.3|
|''Date:''|Feb 24, 2008|
|''Source:''|http://tiddlywiki.bidix.info/#UploadPlugin|
|''Documentation:''|http://tiddlywiki.bidix.info/#UploadPluginDoc|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
|''Requires:''|PasswordOptionPlugin|
***/
//{{{
version.extensions.UploadPlugin = {
major: 4, minor: 1, revision: 3,
date: new Date("Feb 24, 2008"),
source: 'http://tiddlywiki.bidix.info/#UploadPlugin',
author: 'BidiX (BidiX (at) bidix (dot) info',
coreVersion: '2.2.0'
};
//
// Environment
//
if (!window.bidix) window.bidix = {}; // bidix namespace
bidix.debugMode = false; // true to activate both in Plugin and UploadService
//
// Upload Macro
//
config.macros.upload = {
// default values
defaultBackupDir: '', //no backup
defaultStoreScript: "store.php",
defaultToFilename: "index.html",
defaultUploadDir: ".",
authenticateUser: true // UploadService Authenticate User
};
config.macros.upload.label = {
promptOption: "Save and Upload this TiddlyWiki with UploadOptions",
promptParamMacro: "Save and Upload this TiddlyWiki in %0",
saveLabel: "save to web",
saveToDisk: "save to disk",
uploadLabel: "upload"
};
config.macros.upload.messages = {
noStoreUrl: "No store URL in parmeters or options",
usernameOrPasswordMissing: "Username or password missing"
};
config.macros.upload.handler = function(place,macroName,params) {
if (readOnly)
return;
var label;
if (document.location.toString().substr(0,4) == "http")
label = this.label.saveLabel;
else
label = this.label.uploadLabel;
var prompt;
if (params[0]) {
prompt = this.label.promptParamMacro.toString().format([this.destFile(params[0],
(params[1] ? params[1]:bidix.basename(window.location.toString())), params[3])]);
} else {
prompt = this.label.promptOption;
}
createTiddlyButton(place, label, prompt, function() {config.macros.upload.action(params);}, null, null, this.accessKey);
};
config.macros.upload.action = function(params)
{
// for missing macro parameter set value from options
if (!params) params = {};
var storeUrl = params[0] ? params[0] : config.options.txtUploadStoreUrl;
var toFilename = params[1] ? params[1] : config.options.txtUploadFilename;
var backupDir = params[2] ? params[2] : config.options.txtUploadBackupDir;
var uploadDir = params[3] ? params[3] : config.options.txtUploadDir;
var username = params[4] ? params[4] : config.options.txtUploadUserName;
var password = config.options.pasUploadPassword; // for security reason no password as macro parameter
// for still missing parameter set default value
if ((!storeUrl) && (document.location.toString().substr(0,4) == "http"))
storeUrl = bidix.dirname(document.location.toString())+'/'+config.macros.upload.defaultStoreScript;
if (storeUrl.substr(0,4) != "http")
storeUrl = bidix.dirname(document.location.toString()) +'/'+ storeUrl;
if (!toFilename)
toFilename = bidix.basename(window.location.toString());
if (!toFilename)
toFilename = config.macros.upload.defaultToFilename;
if (!uploadDir)
uploadDir = config.macros.upload.defaultUploadDir;
if (!backupDir)
backupDir = config.macros.upload.defaultBackupDir;
// report error if still missing
if (!storeUrl) {
alert(config.macros.upload.messages.noStoreUrl);
clearMessage();
return false;
}
if (config.macros.upload.authenticateUser && (!username || !password)) {
alert(config.macros.upload.messages.usernameOrPasswordMissing);
clearMessage();
return false;
}
bidix.upload.uploadChanges(false,null,storeUrl, toFilename, uploadDir, backupDir, username, password);
return false;
};
config.macros.upload.destFile = function(storeUrl, toFilename, uploadDir)
{
if (!storeUrl)
return null;
var dest = bidix.dirname(storeUrl);
if (uploadDir && uploadDir != '.')
dest = dest + '/' + uploadDir;
dest = dest + '/' + toFilename;
return dest;
};
//
// uploadOptions Macro
//
config.macros.uploadOptions = {
handler: function(place,macroName,params) {
var wizard = new Wizard();
wizard.createWizard(place,this.wizardTitle);
wizard.addStep(this.step1Title,this.step1Html);
var markList = wizard.getElement("markList");
var listWrapper = document.createElement("div");
markList.parentNode.insertBefore(listWrapper,markList);
wizard.setValue("listWrapper",listWrapper);
this.refreshOptions(listWrapper,false);
var uploadCaption;
if (document.location.toString().substr(0,4) == "http")
uploadCaption = config.macros.upload.label.saveLabel;
else
uploadCaption = config.macros.upload.label.uploadLabel;
wizard.setButtons([
{caption: uploadCaption, tooltip: config.macros.upload.label.promptOption,
onClick: config.macros.upload.action},
{caption: this.cancelButton, tooltip: this.cancelButtonPrompt, onClick: this.onCancel}
]);
},
options: [
"txtUploadUserName",
"pasUploadPassword",
"txtUploadStoreUrl",
"txtUploadDir",
"txtUploadFilename",
"txtUploadBackupDir",
"chkUploadLog",
"txtUploadLogMaxLine"
],
refreshOptions: function(listWrapper) {
var opts = [];
for(i=0; i<this.options.length; i++) {
var opt = {};
opts.push();
opt.option = "";
n = this.options[i];
opt.name = n;
opt.lowlight = !config.optionsDesc[n];
opt.description = opt.lowlight ? this.unknownDescription : config.optionsDesc[n];
opts.push(opt);
}
var listview = ListView.create(listWrapper,opts,this.listViewTemplate);
for(n=0; n<opts.length; n++) {
var type = opts[n].name.substr(0,3);
var h = config.macros.option.types[type];
if (h && h.create) {
h.create(opts[n].colElements['option'],type,opts[n].name,opts[n].name,"no");
}
}
},
onCancel: function(e)
{
backstage.switchTab(null);
return false;
},
wizardTitle: "Upload with options",
step1Title: "These options are saved in cookies in your browser",
step1Html: "<input type='hidden' name='markList'></input><br>",
cancelButton: "Cancel",
cancelButtonPrompt: "Cancel prompt",
listViewTemplate: {
columns: [
{name: 'Description', field: 'description', title: "Description", type: 'WikiText'},
{name: 'Option', field: 'option', title: "Option", type: 'String'},
{name: 'Name', field: 'name', title: "Name", type: 'String'}
],
rowClasses: [
{className: 'lowlight', field: 'lowlight'}
]}
};
//
// upload functions
//
if (!bidix.upload) bidix.upload = {};
if (!bidix.upload.messages) bidix.upload.messages = {
//from saving
invalidFileError: "The original file '%0' does not appear to be a valid TiddlyWiki",
backupSaved: "Backup saved",
backupFailed: "Failed to upload backup file",
rssSaved: "RSS feed uploaded",
rssFailed: "Failed to upload RSS feed file",
emptySaved: "Empty template uploaded",
emptyFailed: "Failed to upload empty template file",
mainSaved: "Main TiddlyWiki file uploaded",
mainFailed: "Failed to upload main TiddlyWiki file. Your changes have not been saved",
//specific upload
loadOriginalHttpPostError: "Can't get original file",
aboutToSaveOnHttpPost: 'About to upload on %0 ...',
storePhpNotFound: "The store script '%0' was not found."
};
bidix.upload.uploadChanges = function(onlyIfDirty,tiddlers,storeUrl,toFilename,uploadDir,backupDir,username,password)
{
var callback = function(status,uploadParams,original,url,xhr) {
if (!status) {
displayMessage(bidix.upload.messages.loadOriginalHttpPostError);
return;
}
if (bidix.debugMode)
alert(original.substr(0,500)+"\n...");
// Locate the storeArea div's
var posDiv = locateStoreArea(original);
if((posDiv[0] == -1) || (posDiv[1] == -1)) {
alert(config.messages.invalidFileError.format([localPath]));
return;
}
bidix.upload.uploadRss(uploadParams,original,posDiv);
};
if(onlyIfDirty && !store.isDirty())
return;
clearMessage();
// save on localdisk ?
if (document.location.toString().substr(0,4) == "file") {
var path = document.location.toString();
var localPath = getLocalPath(path);
saveChanges();
}
// get original
var uploadParams = new Array(storeUrl,toFilename,uploadDir,backupDir,username,password);
var originalPath = document.location.toString();
// If url is a directory : add index.html
if (originalPath.charAt(originalPath.length-1) == "/")
originalPath = originalPath + "index.html";
var dest = config.macros.upload.destFile(storeUrl,toFilename,uploadDir);
var log = new bidix.UploadLog();
log.startUpload(storeUrl, dest, uploadDir, backupDir);
displayMessage(bidix.upload.messages.aboutToSaveOnHttpPost.format([dest]));
if (bidix.debugMode)
alert("about to execute Http - GET on "+originalPath);
var r = doHttp("GET",originalPath,null,null,username,password,callback,uploadParams,null);
if (typeof r == "string")
displayMessage(r);
return r;
};
bidix.upload.uploadRss = function(uploadParams,original,posDiv)
{
var callback = function(status,params,responseText,url,xhr) {
if(status) {
var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
displayMessage(bidix.upload.messages.rssSaved,bidix.dirname(url)+'/'+destfile);
bidix.upload.uploadMain(params[0],params[1],params[2]);
} else {
displayMessage(bidix.upload.messages.rssFailed);
}
};
// do uploadRss
if(config.options.chkGenerateAnRssFeed) {
var rssPath = uploadParams[1].substr(0,uploadParams[1].lastIndexOf(".")) + ".xml";
var rssUploadParams = new Array(uploadParams[0],rssPath,uploadParams[2],'',uploadParams[4],uploadParams[5]);
var rssString = generateRss();
// no UnicodeToUTF8 conversion needed when location is "file" !!!
if (document.location.toString().substr(0,4) != "file")
rssString = convertUnicodeToUTF8(rssString);
bidix.upload.httpUpload(rssUploadParams,rssString,callback,Array(uploadParams,original,posDiv));
} else {
bidix.upload.uploadMain(uploadParams,original,posDiv);
}
};
bidix.upload.uploadMain = function(uploadParams,original,posDiv)
{
var callback = function(status,params,responseText,url,xhr) {
var log = new bidix.UploadLog();
if(status) {
// if backupDir specified
if ((params[3]) && (responseText.indexOf("backupfile:") > -1)) {
var backupfile = responseText.substring(responseText.indexOf("backupfile:")+11,responseText.indexOf("\n", responseText.indexOf("backupfile:")));
displayMessage(bidix.upload.messages.backupSaved,bidix.dirname(url)+'/'+backupfile);
}
var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
displayMessage(bidix.upload.messages.mainSaved,bidix.dirname(url)+'/'+destfile);
store.setDirty(false);
log.endUpload("ok");
} else {
alert(bidix.upload.messages.mainFailed);
displayMessage(bidix.upload.messages.mainFailed);
log.endUpload("failed");
}
};
// do uploadMain
var revised = bidix.upload.updateOriginal(original,posDiv);
bidix.upload.httpUpload(uploadParams,revised,callback,uploadParams);
};
bidix.upload.httpUpload = function(uploadParams,data,callback,params)
{
var localCallback = function(status,params,responseText,url,xhr) {
url = (url.indexOf("nocache=") < 0 ? url : url.substring(0,url.indexOf("nocache=")-1));
if (xhr.status == 404)
alert(bidix.upload.messages.storePhpNotFound.format([url]));
if ((bidix.debugMode) || (responseText.indexOf("Debug mode") >= 0 )) {
alert(responseText);
if (responseText.indexOf("Debug mode") >= 0 )
responseText = responseText.substring(responseText.indexOf("\n\n")+2);
} else if (responseText.charAt(0) != '0')
alert(responseText);
if (responseText.charAt(0) != '0')
status = null;
callback(status,params,responseText,url,xhr);
};
// do httpUpload
var boundary = "---------------------------"+"AaB03x";
var uploadFormName = "UploadPlugin";
// compose headers data
var sheader = "";
sheader += "--" + boundary + "\r\nContent-disposition: form-data; name=\"";
sheader += uploadFormName +"\"\r\n\r\n";
sheader += "backupDir="+uploadParams[3] +
";user=" + uploadParams[4] +
";password=" + uploadParams[5] +
";uploaddir=" + uploadParams[2];
if (bidix.debugMode)
sheader += ";debug=1";
sheader += ";;\r\n";
sheader += "\r\n" + "--" + boundary + "\r\n";
sheader += "Content-disposition: form-data; name=\"userfile\"; filename=\""+uploadParams[1]+"\"\r\n";
sheader += "Content-Type: text/html;charset=UTF-8" + "\r\n";
sheader += "Content-Length: " + data.length + "\r\n\r\n";
// compose trailer data
var strailer = new String();
strailer = "\r\n--" + boundary + "--\r\n";
data = sheader + data + strailer;
if (bidix.debugMode) alert("about to execute Http - POST on "+uploadParams[0]+"\n with \n"+data.substr(0,500)+ " ... ");
var r = doHttp("POST",uploadParams[0],data,"multipart/form-data; ;charset=UTF-8; boundary="+boundary,uploadParams[4],uploadParams[5],localCallback,params,null);
if (typeof r == "string")
displayMessage(r);
return r;
};
// same as Saving's updateOriginal but without convertUnicodeToUTF8 calls
bidix.upload.updateOriginal = function(original, posDiv)
{
if (!posDiv)
posDiv = locateStoreArea(original);
if((posDiv[0] == -1) || (posDiv[1] == -1)) {
alert(config.messages.invalidFileError.format([localPath]));
return;
}
var revised = original.substr(0,posDiv[0] + startSaveArea.length) + "\n" +
store.allTiddlersAsHtml() + "\n" +
original.substr(posDiv[1]);
var newSiteTitle = getPageTitle().htmlEncode();
revised = revised.replaceChunk("<title"+">","</title"+">"," " + newSiteTitle + " ");
revised = updateMarkupBlock(revised,"PRE-HEAD","MarkupPreHead");
revised = updateMarkupBlock(revised,"POST-HEAD","MarkupPostHead");
revised = updateMarkupBlock(revised,"PRE-BODY","MarkupPreBody");
revised = updateMarkupBlock(revised,"POST-SCRIPT","MarkupPostBody");
return revised;
};
//
// UploadLog
//
// config.options.chkUploadLog :
// false : no logging
// true : logging
// config.options.txtUploadLogMaxLine :
// -1 : no limit
// 0 : no Log lines but UploadLog is still in place
// n : the last n lines are only kept
// NaN : no limit (-1)
bidix.UploadLog = function() {
if (!config.options.chkUploadLog)
return; // this.tiddler = null
this.tiddler = store.getTiddler("UploadLog");
if (!this.tiddler) {
this.tiddler = new Tiddler();
this.tiddler.title = "UploadLog";
this.tiddler.text = "| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |";
this.tiddler.created = new Date();
this.tiddler.modifier = config.options.txtUserName;
this.tiddler.modified = new Date();
store.addTiddler(this.tiddler);
}
return this;
};
bidix.UploadLog.prototype.addText = function(text) {
if (!this.tiddler)
return;
// retrieve maxLine when we need it
var maxLine = parseInt(config.options.txtUploadLogMaxLine,10);
if (isNaN(maxLine))
maxLine = -1;
// add text
if (maxLine != 0)
this.tiddler.text = this.tiddler.text + text;
// Trunck to maxLine
if (maxLine >= 0) {
var textArray = this.tiddler.text.split('\n');
if (textArray.length > maxLine + 1)
textArray.splice(1,textArray.length-1-maxLine);
this.tiddler.text = textArray.join('\n');
}
// update tiddler fields
this.tiddler.modifier = config.options.txtUserName;
this.tiddler.modified = new Date();
store.addTiddler(this.tiddler);
// refresh and notifiy for immediate update
story.refreshTiddler(this.tiddler.title);
store.notify(this.tiddler.title, true);
};
bidix.UploadLog.prototype.startUpload = function(storeUrl, toFilename, uploadDir, backupDir) {
if (!this.tiddler)
return;
var now = new Date();
var text = "\n| ";
var filename = bidix.basename(document.location.toString());
if (!filename) filename = '/';
text += now.formatString("0DD/0MM/YYYY 0hh:0mm:0ss") +" | ";
text += config.options.txtUserName + " | ";
text += "[["+filename+"|"+location + "]] |";
text += " [[" + bidix.basename(storeUrl) + "|" + storeUrl + "]] | ";
text += uploadDir + " | ";
text += "[[" + bidix.basename(toFilename) + " | " +toFilename + "]] | ";
text += backupDir + " |";
this.addText(text);
};
bidix.UploadLog.prototype.endUpload = function(status) {
if (!this.tiddler)
return;
this.addText(" "+status+" |");
};
//
// Utilities
//
bidix.checkPlugin = function(plugin, major, minor, revision) {
var ext = version.extensions[plugin];
if (!
(ext &&
((ext.major > major) ||
((ext.major == major) && (ext.minor > minor)) ||
((ext.major == major) && (ext.minor == minor) && (ext.revision >= revision))))) {
// write error in PluginManager
if (pluginInfo)
pluginInfo.log.push("Requires " + plugin + " " + major + "." + minor + "." + revision);
eval(plugin); // generate an error : "Error: ReferenceError: xxxx is not defined"
}
};
bidix.dirname = function(filePath) {
if (!filePath)
return;
var lastpos;
if ((lastpos = filePath.lastIndexOf("/")) != -1) {
return filePath.substring(0, lastpos);
} else {
return filePath.substring(0, filePath.lastIndexOf("\\"));
}
};
bidix.basename = function(filePath) {
if (!filePath)
return;
var lastpos;
if ((lastpos = filePath.lastIndexOf("#")) != -1)
filePath = filePath.substring(0, lastpos);
if ((lastpos = filePath.lastIndexOf("/")) != -1) {
return filePath.substring(lastpos + 1);
} else
return filePath.substring(filePath.lastIndexOf("\\")+1);
};
bidix.initOption = function(name,value) {
if (!config.options[name])
config.options[name] = value;
};
//
// Initializations
//
// require PasswordOptionPlugin 1.0.1 or better
bidix.checkPlugin("PasswordOptionPlugin", 1, 0, 1);
// styleSheet
setStylesheet('.txtUploadStoreUrl, .txtUploadBackupDir, .txtUploadDir {width: 22em;}',"uploadPluginStyles");
//optionsDesc
merge(config.optionsDesc,{
txtUploadStoreUrl: "Url of the UploadService script (default: store.php)",
txtUploadFilename: "Filename of the uploaded file (default: in index.html)",
txtUploadDir: "Relative Directory where to store the file (default: . (downloadService directory))",
txtUploadBackupDir: "Relative Directory where to backup the file. If empty no backup. (default: ''(empty))",
txtUploadUserName: "Upload Username",
pasUploadPassword: "Upload Password",
chkUploadLog: "do Logging in UploadLog (default: true)",
txtUploadLogMaxLine: "Maximum of lines in UploadLog (default: 10)"
});
// Options Initializations
bidix.initOption('txtUploadStoreUrl','');
bidix.initOption('txtUploadFilename','');
bidix.initOption('txtUploadDir','');
bidix.initOption('txtUploadBackupDir','');
bidix.initOption('txtUploadUserName','');
bidix.initOption('pasUploadPassword','');
bidix.initOption('chkUploadLog',true);
bidix.initOption('txtUploadLogMaxLine','10');
// Backstage
merge(config.tasks,{
uploadOptions: {text: "upload", tooltip: "Change UploadOptions and Upload", content: '<<uploadOptions>>'}
});
config.backstageTasks.push("uploadOptions");
//}}}
<!--{{{-->
<span class='title' macro='view title'></span>
<span 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>)</span>
<div><span class='toolbar' macro='toolbar [[ToolbarCommands::ViewToolbar]]'></span></div>
<div class='tagging' macro='tagging'></div>
<div class='tagged'>
<div macro='tagger'></div>
<div macro='tags'></div>
</div>
<!-- For DiscussionPlugin / CommentPlugin
<div class='viewer' macro='tabs txtDiscussionTab Page Page CurrentTiddler {{var c=0; if(place) var h=story.findContainingTiddler(place); if(h) c=config.macros.discussion.countComments(h.getAttribute("tiddler")); "Discussion"+(c?" ("+c+")":"")}} Discussion DiscussionTiddler'></div>
-->
<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
<div class='toolbar' macro='toolbar toggleTiddler'></div>
<br /><br />
<!--}}}-->
/***
|''Name:''|WebReadOnlyPlugin|
|''Description:''|Make ~TiddlyWikis readonly over the web|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#WebReadOnlyPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Beta|
|''Date:''|June 20, 2010|
|''Comments:''| |
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Make ~TiddlyWikis readonly over the web
!!Usage
#Import
#Save & Reload
!!Code
***/
//{{{
if (document.location.toString().substr(0,4).toLowerCase() == "http"){
showBackstage = false;
readOnly = true;
// toolbar
store.saveTiddler(null,"ToolbarCommands","|~ViewToolbar|closeTiddler closeOthers permalink references jump +collapseOthers|\n|~EditToolbar||");
function confirmExit(){ // disable confirm exit
hadConfirmExit = true;
return;
};
}
//}}}
//{{{
if(window.location.protocol == "file:"){
config.options.chkDisableTabsBar = false;
config.options.chkDisableWikiLinks = true;
config.options.chkSaveBackups = false;
//config.options.chkAutoSave = false;
//config.options.chkRegExpSearch = false;
//config.options.chkCaseSensitiveSearch = false;
//config.options.chkIncrementalSearch = true;
//config.options.chkAnimate = true;
//config.options.chkGenerateAnRssFeed = false;
//config.options.chkSaveEmptyTemplate = false;
//config.options.chkOpenInNewWindow = true;
//config.options.chkToggleLinks = false;
//config.options.chkHttpReadOnly = true;
//config.options.chkForceMinorUpdate = false;
//config.options.chkConfirmDelete = true;
config.options.chkInsertTabs = true;
config.options.chkUsePreForStorage = true; //Whethertouse<pre>formatforstorage
//config.options.chkDisplayInstrumentation = false;
//config.options.txtBackupFolder = "";
//config.options.txtEditorFocus = "text";
//config.options.txtMainTab = "tabTimeline";
//config.options.txtMoreTab = "moreTabAll";
config.options.txtMaxEditRows = "40";
//config.options.txtFileSystemCharSet = "UTF-8";
config.options.txtTheme = "";
config.options.txtUserName="KennyZ";
}
//}}}
/***
|''Name:''|WordCountPlugin|
|''Description:''|wc in unix|
|''Author:''|Kenny Z|
|''Source:''|http://cooltool.tiddlyspot.com/#WordCountPlugin|
|''CodeRepository:''| |
|''Version:''|0.0.1|
|''Status:''|Alpha|
|''Date:''|June 25, 2010|
|''Comments:''||
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |
|''~CoreVersion:''|2.6|
!!Description
Count the number of words.
!!Usage
Add "{{{wordCount}}}" to [[ToolbarCommands]] in the ~ViewToolbar slice.
!!Configuration
Max recursive tiddler text level to follow: <<option txtRecursiveTiddlerTextLevel>> (e.g. If a tiddler includes {{{[[linked tiddler]]}}})
!!Code
***/
//{{{
if(!config.options.txtRecursiveTiddlerTextLevel)
config.options.txtRecursiveTiddlerTextLevel = 0;
if(!version.extensions.wordCount) {
version.extensions.wordCount= {installed:true};
config.commands.wordCount= {
text: "wc",
tooltip: "Word Count",
sep: '\n',
handler: function(event,src,title) {
var txt= store.getRecursiveTiddlerText(title,'',config.options.txtRecursiveTiddlerTextLevel);
var list = [];
list.push('Bytes: '+wc.getBytes(txt));
list.push('Words (online): '+txt.split(/\s+/gim).length);
//list.push('Characters : '+wc.getBytes(txt.replace(/\r|\n/gim,'')) // NL not a character
// +', '+wc.getBytes(txt.replace(/\s+/gim,'')) +'(no spaces)');
list.push('UTF-8 Characters : '+txt.replace(/\r|\n/gim,'').length // NL not a character
+', '+txt.replace(/\s+/gim,'').length+'(no spaces)');
var arr=txt.split(/\n/gm);
list.push('Lines: '+ arr.length +', '+wc.nonblankLines(arr)+'(nonblank)');
list.push('Chars on longest line: '+ wc.longestLine(arr));
list.push('Chars on shortest nonblank line: '+ wc.shortestNonblankLine(arr));
list.push('SHA-1 hash of text:\n\t'+store.getTiddler(title).generateFingerprint());
alert(list.join(wc.sep)); // Display
},
getBytes: function(str){
var count= 0;
for(var i=0; i<str.length;i++){
c = str.charCodeAt(i);
if(c<128) count++;
else if((c>191)&&(c<224)) count +=2;
else count+=3;
}
return count;
},
longestLine: function(arr){
var max = 0;
for(var i=0; i< arr.length; i++){
if(max < arr[i].length) max = arr[i].length;
}
return max;
},
shortestNonblankLine: function(arr){
var min = Number.MAX_VALUE;
for(var i=0; i< arr.length; i++){
if((wc.trim(arr[i]) !='')&&(min > arr[i].length)) min = arr[i].length;
}
return min;
},
nonblankLines: function(arr){
var count=0;
for(var i=0; i< arr.length; i++){
if(wc.trim(arr[i])!='') count++;
}
return count;
},
trim: function(txt){
return txt.replace(/^\s+|\s+$/g,'');
},
};
var wc = config.commands.wordCount;
} //# end of 'install only once'
//}}}
/***
|''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:''|© 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="…";};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\">© 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 of <span class=\"yourSearchCount\" macro=\"yourSearch count\"></span>\n"+"\t\tfor <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> - \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;};})();}
//%/
!usage
{{{[img[clearChangeCount.png]]}}}
[img[clearChangeCount.png]]
!notes
attached by FileDropPlugin
!type
image/png
!file
!url
!hiddenData
/%
!data

!endHiddenData
%/
Type the text for 'New Tiddler'
/%:^^Mailto:^^ [img[mailator.png]] [[Or By Contact Form|http://whspr.me/2s9]] %/
<html>
<iframe src="http://spreadsheets.google.com/embeddedform?formkey=cmh2UW5INHI2eGVsU20xZFMwaTR1X0E6MA.." width="760" height="800" frameborder="0" marginheight="0" marginwidth="0">Loading...</iframe>
</html>
// Copyright (c) 2006, 2008 Tony Garnock-Jones <tonyg@lshift.net>
// Copyright (c) 2006, 2008 LShift Ltd. <query@lshift.net>
//
// Permission is hereby granted, free of charge, to any person
// obtaining a copy of this software and associated documentation files
// (the "Software"), to deal in the Software without restriction,
// including without limitation the rights to use, copy, modify, merge,
// publish, distribute, sublicense, and/or sell copies of the Software,
// and to permit persons to whom the Software is furnished to do so,
// subject to the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
// BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
Diff = {
longest_common_subsequence: function(file1, file2) {
/* Text diff algorithm following Hunt and McIlroy 1976.
* J. W. Hunt and M. D. McIlroy, An algorithm for differential file
* comparison, Bell Telephone Laboratories CSTR #41 (1976)
* http://www.cs.dartmouth.edu/~doug/
*
* Expects two arrays of strings.
*/
var equivalenceClasses;
var file2indices;
var newCandidate;
var candidates;
var line;
var c, i, j, jX, r, s;
equivalenceClasses = {};
for (j = 0; j < file2.length; j++) {
line = file2[j];
if (equivalenceClasses[line]) {
equivalenceClasses[line].push(j);
} else {
equivalenceClasses[line] = [j];
}
}
candidates = [{file1index: -1,
file2index: -1,
chain: null}];
for (i = 0; i < file1.length; i++) {
line = file1[i];
file2indices = equivalenceClasses[line] || [];
r = 0;
c = candidates[0];
for (jX = 0; jX < file2indices.length; jX++) {
j = file2indices[jX];
for (s = 0; s < candidates.length; s++) {
if ((candidates[s].file2index < j) &&
((s == candidates.length - 1) ||
(candidates[s + 1].file2index > j)))
break;
}
if (s < candidates.length) {
newCandidate = {file1index: i,
file2index: j,
chain: candidates[s]};
if (r == candidates.length) {
candidates.push(c);
} else {
candidates[r] = c;
}
r = s + 1;
c = newCandidate;
if (r == candidates.length) {
break; // no point in examining further (j)s
}
}
}
candidates[r] = c;
}
// At this point, we know the LCS: it's in the reverse of the
// linked-list through .chain of
// candidates[candidates.length - 1].
return candidates[candidates.length - 1];
},
diff_comm: function(file1, file2) {
// We apply the LCS to build a "comm"-style picture of the
// differences between file1 and file2.
var result = [];
var tail1 = file1.length;
var tail2 = file2.length;
var common = {common: []};
function processCommon() {
if (common.common.length) {
common.common.reverse();
result.push(common);
common = {common: []};
}
}
for (var candidate = Diff.longest_common_subsequence(file1, file2);
candidate !== null;
candidate = candidate.chain)
{
var different = {file1: [], file2: []};
while (--tail1 > candidate.file1index) {
different.file1.push(file1[tail1]);
}
while (--tail2 > candidate.file2index) {
different.file2.push(file2[tail2]);
}
if (different.file1.length || different.file2.length) {
processCommon();
different.file1.reverse();
different.file2.reverse();
result.push(different);
}
if (tail1 >= 0) {
common.common.push(file1[tail1]);
}
}
processCommon();
result.reverse();
return result;
},
diff_patch: function(file1, file2) {
// We apply the LCD to build a JSON representation of a
// diff(1)-style patch.
var result = [];
var tail1 = file1.length;
var tail2 = file2.length;
function chunkDescription(file, offset, length) {
var chunk = [];
for (var i = 0; i < length; i++) {
chunk.push(file[offset + i]);
}
return {offset: offset,
length: length,
chunk: chunk};
}
for (var candidate = Diff.longest_common_subsequence(file1, file2);
candidate !== null;
candidate = candidate.chain)
{
var mismatchLength1 = tail1 - candidate.file1index - 1;
var mismatchLength2 = tail2 - candidate.file2index - 1;
tail1 = candidate.file1index;
tail2 = candidate.file2index;
if (mismatchLength1 || mismatchLength2) {
result.push({file1: chunkDescription(file1,
candidate.file1index + 1,
mismatchLength1),
file2: chunkDescription(file2,
candidate.file2index + 1,
mismatchLength2)});
}
}
result.reverse();
return result;
},
invert_patch: function(patch) {
// Takes the output of Diff.diff_patch(), and inverts the
// sense of it, so that it can be applied to file2 to give
// file1 rather than the other way around.
for (var i = 0; i < patch.length; i++) {
var chunk = patch[i];
var tmp = chunk.file1;
chunk.file1 = chunk.file2;
chunk.file2 = tmp;
}
},
patch: function (file, patch) {
// Applies a patch to a file.
//
// Given file1 and file2, Diff.patch(file1,
// Diff.diff_patch(file1, file2)) should give file2.
var result = [];
var commonOffset = 0;
function copyCommon(targetOffset) {
while (commonOffset < targetOffset) {
result.push(file[commonOffset]);
commonOffset++;
}
}
for (var chunkIndex = 0; chunkIndex < patch.length; chunkIndex++) {
var chunk = patch[chunkIndex];
copyCommon(chunk.file1.offset);
for (var lineIndex = 0; lineIndex < chunk.file2.length; lineIndex++) {
result.push(chunk.file2.chunk[lineIndex]);
}
commonOffset += chunk.file1.length;
}
copyCommon(file.length);
return result;
},
diff_indices: function(file1, file2) {
// We apply the LCS to give a simple representation of the
// offsets and lengths of mismatched chunks in the input
// files. This is used by diff3_merge_indices below.
var result = [];
var tail1 = file1.length;
var tail2 = file2.length;
for (var candidate = Diff.longest_common_subsequence(file1, file2);
candidate !== null;
candidate = candidate.chain)
{
var mismatchLength1 = tail1 - candidate.file1index - 1;
var mismatchLength2 = tail2 - candidate.file2index - 1;
tail1 = candidate.file1index;
tail2 = candidate.file2index;
if (mismatchLength1 || mismatchLength2) {
result.push({file1: [tail1 + 1, mismatchLength1],
file2: [tail2 + 1, mismatchLength2]});
}
}
result.reverse();
return result;
},
diff3_merge_indices: function (a, o, b) {
// Given three files, A, O, and B, where both A and B are
// independently derived from O, returns a fairly complicated
// internal representation of merge decisions it's taken. The
// interested reader may wish to consult
//
// Sanjeev Khanna, Keshav Kunal, and Benjamin C. Pierce. "A
// Formal Investigation of Diff3." In Arvind and Prasad,
// editors, Foundations of Software Technology and Theoretical
// Computer Science (FSTTCS), December 2007.
//
// (http://www.cis.upenn.edu/~bcpierce/papers/diff3-short.pdf)
var i;
var m1 = Diff.diff_indices(o, a);
var m2 = Diff.diff_indices(o, b);
var hunks = [];
function addHunk(h, side) {
hunks.push([h.file1[0], side, h.file1[1], h.file2[0], h.file2[1]]);
}
for (i = 0; i < m1.length; i++) { addHunk(m1[i], 0); }
for (i = 0; i < m2.length; i++) { addHunk(m2[i], 2); }
hunks.sort();
var result = [];
var commonOffset = 0;
function copyCommon(targetOffset) {
if (targetOffset > commonOffset) {
result.push([1, commonOffset, targetOffset - commonOffset]);
commonOffset = targetOffset;
}
}
for (var hunkIndex = 0; hunkIndex < hunks.length; hunkIndex++) {
var firstHunkIndex = hunkIndex;
var hunk = hunks[hunkIndex];
var regionLhs = hunk[0];
var regionRhs = regionLhs + hunk[2];
while (hunkIndex < hunks.length - 1) {
var maybeOverlapping = hunks[hunkIndex + 1];
var maybeLhs = maybeOverlapping[0];
if (maybeLhs >= regionRhs) break;
regionRhs = maybeLhs + maybeOverlapping[2];
hunkIndex++;
}
copyCommon(regionLhs);
if (firstHunkIndex == hunkIndex) {
if (hunk[4] > 0) {
result.push([hunk[1], hunk[3], hunk[4]]);
}
} else {
var regions = [a.length, -1, regionLhs, regionRhs, b.length, -1];
for (i = firstHunkIndex; i <= hunkIndex; i++) {
var side = hunks[i][1];
var lhs = hunks[i][3];
var rhs = lhs + hunks[i][4];
var ri = side * 2;
regions[ri] = Math.min(lhs, regions[ri]);
regions[ri+1] = Math.max(rhs, regions[ri+1]);
}
result.push([-1,
regions[0], regions[1] - regions[0],
regions[2], regions[3] - regions[2],
regions[4], regions[5] - regions[4]]);
}
commonOffset = regionRhs;
}
copyCommon(o.length);
return result;
},
diff3_merge: function (a, o, b, excludeFalseConflicts) {
// Applies the output of Diff.diff3_merge_indices to actually
// construct the merged file; the returned result alternates
// between "ok" and "conflict" blocks.
var result = [];
var files = [a, o, b];
var indices = Diff.diff3_merge_indices(a, o, b);
var okLines = [];
function flushOk() {
if (okLines) {
result.push({ok: okLines});
}
okLines = [];
}
function pushOk(xs) {
for (var j = 0; j < xs.length; j++) {
okLines.push(xs[j]);
}
}
function isTrueConflict(rec) {
if (rec[2] != rec[6]) return true;
var aoff = rec[1];
var boff = rec[5];
for (var j = 0; j < rec[2]; j++) {
if (a[j + aoff] != b[j + boff]) return true;
}
return false;
}
for (var i = 0; i < indices.length; i++) {
var x = indices[i];
var side = x[0];
if (side == -1) {
if (excludeFalseConflicts && !isTrueConflict(x)) {
pushOk(files[0].slice(x[1], x[1] + x[2]));
} else {
flushOk();
result.push({conflict: {a: a.slice(x[1], x[1] + x[2]),
aIndex: x[1],
o: o.slice(x[3], x[3] + x[4]),
oIndex: x[3],
b: b.slice(x[5], x[5] + x[6]),
bIndex: x[5]}});
}
} else {
pushOk(files[side].slice(x[1], x[1] + x[2]));
}
}
flushOk();
return result;
}
};
Enter any javascript reference and click ''eval'' to get its value:
<html><form class="eval" style="display:inline;margin:0;padding:0;white-space:nowrap;"
action="#" onsubmit="(document.getElementById('output').innerHTML) =
('\n<p>' + eval(document.getElementById('input').value) + '</p>')">
<input type=text id="input" style="width:90%" value="document.cookie;"
onkeydown="if(event.keyCode==13){this.form.onsubmit(); return false;}" /><br />
<input type=reset value="Clear" style="width:4em" onclick="
document.getElementById('output').innerHTML='';this.form.input.focus()" />
<input type=button value="X" style="width:2em" onclick="
document.getElementById('output').innerHTML='';this.form.input.focus()" />
<input type=button value="eval" style="width:4em" onclick="this.form.onsubmit()" />
</form><div id='output' style="background-color:WhiteSmoke !important;"></div></html>
!usage
{{{[img[exportCommandPlugin.png]]}}}
[img[exportCommandPlugin.png]]
!notes
attached by FileDropPlugin
!type
image/png
!file
!url
!hiddenData
/%
!data

!endHiddenData
%/
// Copyright (c) 2008 Tony Garnock-Jones <tonyg@lshift.net>
// Copyright (c) 2008 LShift Ltd. <query@lshift.net>
//
// Permission is hereby granted, free of charge, to any person
// obtaining a copy of this software and associated documentation files
// (the "Software"), to deal in the Software without restriction,
// including without limitation the rights to use, copy, modify, merge,
// publish, distribute, sublicense, and/or sell copies of the Software,
// and to permit persons to whom the Software is furnished to do so,
// subject to the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
// BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
var Dvcs = {
_debugMode: false,
Util: {
random_hex_string: function(n) {
var digits = "0123456789abcdef";
var result = "";
for (var i = 0; i < n; i++) {
result = result + digits[Math.floor(Math.random() * 16)];
}
return result;
},
random_uuid: function() {
if (Dvcs._debugMode) {
return Dvcs.Util.random_hex_string(8);
} else {
return [Dvcs.Util.random_hex_string(8),
Dvcs.Util.random_hex_string(4),
"4" + Dvcs.Util.random_hex_string(3),
((Math.floor(Math.random() * 256) & ~64) | 128).toString(16) +
Dvcs.Util.random_hex_string(2),
Dvcs.Util.random_hex_string(12)].join("-");
}
},
dict_union: function(s1, s2) {
var result = {};
var k;
for (k in s2) { result[k] = s2[k]; }
for (k in s1) { result[k] = s1[k]; }
return result;
},
dict_difference: function(s1, s2) {
var result = {};
var k;
for (k in s1) { result[k] = s1[k]; }
for (k in s2) { delete result[k]; }
return result;
},
dict_to_set: function(d) {
for (var k in d) { d[k] = 1; }
return d;
},
deepCopy: function(obj) {
// Courtesy of
// http://keithdevens.com/weblog/archive/2007/Jun/07/javascript.clone
//
// Does not handle recursive structures.
if (obj === null || typeof(obj) != 'object') {
return obj;
}
var temp = obj.constructor();
for (var key in obj) {
temp[key] = Dvcs.Util.deepCopy(obj[key]);
}
return temp;
}
},
Mergers: {
simpleScalarMerger: function(v1, v0, v2) {
if (v1 == v2) return [{ok: v1}];
if (v1 == v0) return [{ok: v2}];
if (v2 == v0) return [{ok: v1}];
return [{conflict: {a: v1, o: v0, b: v2}}];
},
simpleTextualMerger: function(v1, v0, v2) {
return Diff.diff3_merge(v1, v0, v2, true);
},
Defaults: {}
},
Checkout: function(directParent, additionalParent, currentBranch) {
this.inodes = {};
this.directParent = directParent;
this.additionalParent = additionalParent;
this.dirty = {};
this.anyDirty = false;
this.currentBranch = currentBranch;
},
Repository: function() {
this.bodies = {};
this.revisions = {};
this.children = {};
}
};
Dvcs.Mergers.Defaults["text"] = Dvcs.Mergers.simpleTextualMerger;
Dvcs.Checkout.prototype.setDirty = function(uuid) {
this.dirty[uuid] = uuid;
this.anyDirty = true;
}
Dvcs.Checkout.prototype.createFile = function() {
var uuid = Dvcs.Util.random_uuid();
if (Dvcs._debugMode) { uuid = "inode-" + uuid; }
this.inodes[uuid] = {};
this.setDirty(uuid);
return uuid;
};
Dvcs.Checkout.prototype.deleteFile = function(uuid) {
if (!this.inodes[uuid]) return false;
delete this.inodes[uuid];
this.anyDirty = true;
return true;
};
Dvcs.Checkout.prototype.fileExists = function(uuid) {
return !!(this.inodes[uuid]);
};
Dvcs.Checkout.prototype.hasProp = function(uuid, prop) {
var inode = this.inodes[uuid];
if (!inode) return null;
return (inode[prop] !== undefined);
}
Dvcs.Checkout.prototype.getProp = function(uuid, prop, defaultValue) {
var inode = this.inodes[uuid];
if (!inode) return null;
var v = inode[prop];
if (v === undefined) {
return defaultValue;
} else {
return Dvcs.Util.deepCopy(v);
}
};
Dvcs.Checkout.prototype.setProp = function(uuid, prop, value) {
var inode = this.inodes[uuid];
if (!inode) return false;
inode[prop] = value;
this.setDirty(uuid);
return true;
};
Dvcs.Checkout.prototype.clearProp = function(uuid, prop) {
var inode = this.inodes[uuid];
if (!inode) return null;
if (inode[prop] !== undefined) {
delete inode[prop];
this.setDirty(uuid);
}
return true;
}
Dvcs.Checkout.prototype.forEachProp = function(uuid, f) {
var inode = this.inodes[uuid];
if (!inode) return null;
for (var prop in inode) {
f(prop, inode[prop]);
}
}
Dvcs.Checkout.prototype.forEachFile = function(f) {
for (var uuid in this.inodes) {
f(uuid);
}
};
Dvcs.Checkout.prototype.getBranch = function() {
return this.currentBranch;
};
Dvcs.Checkout.prototype.setBranch = function(newBranch) {
this.currentBranch = newBranch;
};
Dvcs.Checkout.prototype.clone = function() {
var result = new Dvcs.Checkout(this.directParent,
this.additionalParent,
this.currentBranch);
result.inodes = Dvcs.Util.deepCopy(this.inodes);
return result;
};
Dvcs.Repository.prototype.resolveRevId = function(revId) {
if (this.revisions[revId]) {
return revId;
} else {
return this.branchTip(revId);
}
};
Dvcs.Repository.prototype.lookupRev = function(revId, shouldResolve) {
var candidate = this.revisions[revId];
if (!candidate && (shouldResolve !== false)) {
// shouldResolve is an optional parameter, hence the odd test in the line above
candidate = this.revisions[this.branchTip(revId)];
}
return candidate
|| { alive: {},
dead: {},
changed: [],
branch: null,
timestamp: 0,
metadata: null,
directParent: null,
additionalParent: null };
};
Dvcs.Repository.prototype.getMetadata = function(revId, shouldResolve) {
return this.lookupRev(revId, shouldResolve).metadata;
};
Dvcs.Repository.prototype.getBody = function(revRecord, aliveInodeId) {
var bodyId = revRecord.alive[aliveInodeId];
if (!bodyId) return {};
return Dvcs.Util.deepCopy(this.bodies[bodyId]);
};
Dvcs.Repository.prototype.update = function(unresolvedRevId) {
var revId = this.resolveRevId(unresolvedRevId);
var rev = this.revisions[revId];
if (!rev) {
if (unresolvedRevId === null) {
// meaning "default branch". We only get here if the user
// asked for the default branch and there are currently no
// commits at all in the repo. Hand back an empty
// checkout.
return new Dvcs.Checkout(null, null, null);
} else {
// Couldn't find what the user asked for.
return null;
}
}
var fs = new Dvcs.Checkout(revId, null, rev.branch);
for (var inode in rev.alive) {
fs.inodes[inode] = this.getBody(rev, inode);
}
return fs;
};
Dvcs.Repository.prototype.commit = function(fs, metadata) {
if (!fs.anyDirty) {
return null;
}
var directParentRev = this.lookupRev(fs.directParent);
var additionalParentRev = this.lookupRev(fs.additionalParent);
var oldAlive = Dvcs.Util.dict_union(directParentRev.alive, additionalParentRev.alive);
var oldDead = Dvcs.Util.dict_union(directParentRev.dead, additionalParentRev.dead);
var newChanged = [];
var newAlive = {};
for (var inodeId in fs.inodes) {
if (fs.dirty[inodeId]) {
var newBodyId = Dvcs.Util.random_uuid();
if (Dvcs._debugMode) { newBodyId = "body-" + newBodyId; }
this.bodies[newBodyId] = Dvcs.Util.deepCopy(fs.inodes[inodeId]);
newAlive[inodeId] = newBodyId;
newChanged.push(inodeId);
} else {
newAlive[inodeId] = oldAlive[inodeId];
}
}
var newDead = Dvcs.Util.dict_to_set(Dvcs.Util.dict_union(oldDead,
Dvcs.Util.dict_difference(oldAlive,
newAlive)));
var rev = { alive: newAlive,
dead: newDead,
changed: newChanged,
branch: fs.getBranch(),
timestamp: (new Date()).getTime(),
metadata: metadata,
directParent: fs.directParent,
additionalParent: fs.additionalParent };
var newRevId = Dvcs.Util.random_uuid();
if (Dvcs._debugMode) { newRevId = "rev-" + newRevId; }
this.recordRevision(newRevId, rev);
fs.directParent = newRevId;
fs.additionalParent = null;
fs.dirty = {};
fs.anyDirty = false;
return newRevId;
};
Dvcs.Repository.prototype.lookupParents = function (revId) {
var r = this.lookupRev(revId);
var result = [];
if (r.directParent) result.push(r.directParent);
if (r.additionalParent) result.push(r.additionalParent);
return result;
};
Dvcs.Repository.prototype.canMerge = function(r1, r2) {
var $elf = this;
function lookupParents(revId) { return $elf.lookupParents(revId); }
var ancestorRevId = Graph.least_common_ancestor(lookupParents, r1, r2);
return !(r1 == ancestorRevId || r2 == ancestorRevId);
}
Dvcs.Repository.prototype.merge = function(r1, r2) {
var rev1 = this.lookupRev(r1);
var rev2 = this.lookupRev(r2);
var $elf = this;
function lookupParents(revId) { return $elf.lookupParents(revId); }
var ancestorRevId = Graph.least_common_ancestor(lookupParents, r1, r2);
var ancestorRev = this.lookupRev(ancestorRevId, false);
if (r1 == ancestorRevId || r2 == ancestorRevId) {
return null;
}
var fs = this.update(r1);
fs.additionalParent = r2;
fs.anyDirty = true;
var conflicts = [];
for (var deadInode in rev2.dead) {
fs.deleteFile(deadInode);
}
for (var aliveInode in rev2.alive) {
if (fs.fileExists(aliveInode)) {
if (ancestorRev.alive[aliveInode] != rev1.alive[aliveInode] ||
ancestorRev.alive[aliveInode] != rev2.alive[aliveInode])
{
// It has a different body from the ancestor in one or
// both of the revs being merged.
var body0 = this.getBody(ancestorRev, aliveInode);
var body1 = fs.inodes[aliveInode];
var body2 = this.getBody(rev2, aliveInode);
this.mergeBodies(body1, body0, body2,
function (mergedBody) {
fs.inodes[aliveInode] = mergedBody;
fs.setDirty(aliveInode);
},
function (partialResult, conflictDetails) {
conflicts.push({inode: aliveInode,
partialResult: partialResult,
conflictDetails: conflictDetails});
});
} else {
// It is unchanged. Leave it alone.
}
} else if (!rev1.dead[aliveInode]) {
fs.inodes[aliveInode] = this.getBody(rev2, aliveInode);
fs.setDirty(aliveInode);
}
}
return {files: fs, conflicts: conflicts, ancestor: ancestorRevId};
};
Dvcs.Repository.prototype.lookupMerger = function(prop) {
return Dvcs.Mergers.Defaults[prop] || Dvcs.Mergers.simpleScalarMerger;
};
Dvcs.Repository.prototype.mergeBodies = function(bThis, bBase, bOther, kSuccess, kConflict) {
var props = Dvcs.Util.dict_union(bThis, bOther);
var bResult = {};
var failures = {};
var haveConflicts = false;
for (var prop in props) {
var merger = this.lookupMerger(prop);
var mergedPropValue = merger(bThis[prop], bBase[prop], bOther[prop]);
if (mergedPropValue.length == 1 && mergedPropValue[0].ok) {
bResult[prop] = mergedPropValue[0].ok;
} else {
failures[prop] = mergedPropValue;
haveConflicts = true;
}
}
if (haveConflicts) {
return kConflict(bResult, failures);
} else {
return kSuccess(bResult);
}
};
Dvcs.Repository.prototype.recordRevision = function(newRevId, rev) {
var $elf = this;
function addChild(parentId) {
if (parentId === null) return;
if (!$elf.children[parentId]) {
$elf.children[parentId] = [newRevId];
} else {
$elf.children[parentId].push(newRevId);
}
}
this.revisions[newRevId] = rev;
addChild(rev.directParent);
addChild(rev.additionalParent);
};
Dvcs.Repository.prototype.exportRevisions = function(revIds) {
if (revIds) {
var revs = {};
for (var i = 0; i < revIds; i++) {
var rev = this.revisions[revIds[i]];
if (rev) revs[revIds[i]] = rev;
}
var bodies = {};
for (var revId in revs) {
var alive = revs[revId].alive;
for (var inodeId in alive) {
var bodyId = alive[inodeId];
bodies[bodyId] = this.bodies[bodyId];
}
}
return {revisions: revs, bodies: bodies};
} else {
// Shortcut for all revisions. Be warned: shares structure!
return {revisions: this.revisions, bodies: this.bodies};
}
};
Dvcs.Repository.prototype.importRevisions = function(e) {
var stats = {
bodyCount: 0,
bodyDups: 0,
revCount: 0,
revDups: 0
};
for (var bodyId in e.bodies) {
if (!this.bodies[bodyId]) {
this.bodies[bodyId] = e.bodies[bodyId];
stats.bodyCount++;
} else {
stats.bodyDups++;
}
}
for (var revId in e.revisions) {
if (!this.revisions[revId]) {
this.recordRevision(revId, e.revisions[revId]);
stats.revCount++;
} else {
stats.revDups++;
}
}
return stats;
};
Dvcs.Repository.prototype.allRevisions = function() {
return Dvcs.Util.dict_to_set(this.revisions);
};
Dvcs.Repository.prototype.branchHeads = function(branch) {
var result = [];
for (var revId in this.revisions) {
var rev = this.revisions[revId];
if (rev.branch == branch) {
var hasChildrenWithinBranch = false;
var kids = this.children[revId] || [];
for (var i = 0; i < kids.length; i++) {
if (this.revisions[kids[i]].branch == branch) {
hasChildrenWithinBranch = true;
break;
}
}
if (!hasChildrenWithinBranch) {
result.push(revId);
}
}
}
return result;
};
Dvcs.Repository.prototype.branchTip = function(branch) {
var newestHead = null;
var newestRev = null;
var branchHeads = this.branchHeads(branch);
for (var i = 0; i < branchHeads.length; i++) {
var id = branchHeads[i];
var rev = this.lookupRev(id);
if (newestHead === null || newestRev.timestamp < rev.timestamp) {
newestHead = id;
newestRev = rev;
}
}
return newestHead;
};
Dvcs.Repository.prototype.allBranches = function() {
var branches = {};
for (var revId in this.revisions) {
var rev = this.revisions[revId];
var branch = rev.branch;
var branchRecord = branches[branch];
if (!branchRecord) {
branchRecord = { active: false, heads: [] };
branches[branch] = branchRecord;
}
var hasChildrenWithinBranch = false;
var kids = this.children[revId] || [];
for (var i = 0; i < kids.length; i++) {
if (this.revisions[kids[i]].branch == branch) {
hasChildrenWithinBranch = true;
break;
}
}
if (!hasChildrenWithinBranch) {
branchRecord.heads.push(revId);
if (kids.length === 0) {
branchRecord.active = true;
}
}
}
return branches;
};
Dvcs.Repository.prototype.childlessRevisions = function() {
var result = [];
for (var revId in this.revisions) {
var kids = this.children[revId] || [];
if (kids.length === 0) {
result.push(revId);
}
}
var revs = this.revisions;
result.sort(function (r1, r2) { return revs[r2].timestamp - revs[r1].timestamp; });
return result;
};
Dvcs.Repository.prototype.fileRevisions = function(uuid) {
var result = {};
for (var revId in this.revisions) {
var rev = this.revisions[revId];
for (var i = rev.changed.length - 1; i >= 0; i--) {
if (uuid == rev.changed[i]) {
result[revId] = rev;
break;
}
}
}
return result;
};
// Copyright (c) 2008 Tony Garnock-Jones <tonyg@lshift.net>
// Copyright (c) 2008 LShift Ltd. <query@lshift.net>
//
// Permission is hereby granted, free of charge, to any person
// obtaining a copy of this software and associated documentation files
// (the "Software"), to deal in the Software without restriction,
// including without limitation the rights to use, copy, modify, merge,
// publish, distribute, sublicense, and/or sell copies of the Software,
// and to permit persons to whom the Software is furnished to do so,
// subject to the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
// BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
Graph = {
_foreach: function(arr, f) {
for (var i = 0; i < arr.length; i++) {
f(arr[i]);
}
},
least_common_ancestor: function(parentsFun, leafId1, leafId2) {
/* This is a pretty crude approximation. Since we're working
with DAGs, rather than trees, it may not return the very very
least common ancestor. */
var potentialMatches = {};
function augmentPotentialMatches(nodeId) {
if (!potentialMatches[nodeId]) {
potentialMatches[nodeId] = nodeId;
Graph._foreach(parentsFun(nodeId), augmentPotentialMatches);
}
}
augmentPotentialMatches(leafId2);
var searchOrder = [leafId1];
function queueForExamination(nodeId) {
searchOrder.push(nodeId);
}
while (searchOrder.length) {
var candidateId = searchOrder.shift();
if (potentialMatches[candidateId]) {
return candidateId;
} else {
Graph._foreach(parentsFun(candidateId), queueForExamination);
}
}
return null; // no LCA found.
}
};
<<history>>First Draft:
This is the first draft. lalalalalala
==================================================================>>>>>>>>>> ''LOOK!!''
/*
http://www.JSON.org/json2.js
2008-06-08
Public Domain.
NO WARRANTY EXPRESSED OR IMPLIED. USE AT YOUR OWN RISK.
See http://www.JSON.org/js.html
This file creates a global JSON object containing two methods: stringify
and parse.
JSON.stringify(value, replacer, space)
value any JavaScript value, usually an object or array.
replacer an optional parameter that determines how object
values are stringified for objects without a toJSON
method. It can be a function or an array.
space an optional parameter that specifies the indentation
of nested structures. If it is omitted, the text will
be packed without extra whitespace. If it is a number,
it will specify the number of spaces to indent at each
level. If it is a string (such as '\t' or ' '),
it contains the characters used to indent at each level.
This method produces a JSON text from a JavaScript value.
When an object value is found, if the object contains a toJSON
method, its toJSON method will be called and the result will be
stringified. A toJSON method does not serialize: it returns the
value represented by the name/value pair that should be serialized,
or undefined if nothing should be serialized. The toJSON method
will be passed the key associated with the value, and this will be
bound to the object holding the key.
For example, this would serialize Dates as ISO strings.
Date.prototype.toJSON = function (key) {
function f(n) {
// Format integers to have at least two digits.
return n < 10 ? '0' + n : n;
}
return this.getUTCFullYear() + '-' +
f(this.getUTCMonth() + 1) + '-' +
f(this.getUTCDate()) + 'T' +
f(this.getUTCHours()) + ':' +
f(this.getUTCMinutes()) + ':' +
f(this.getUTCSeconds()) + 'Z';
};
You can provide an optional replacer method. It will be passed the
key and value of each member, with this bound to the containing
object. The value that is returned from your method will be
serialized. If your method returns undefined, then the member will
be excluded from the serialization.
If the replacer parameter is an array, then it will be used to
select the members to be serialized. It filters the results such
that only members with keys listed in the replacer array are
stringified.
Values that do not have JSON representaions, such as undefined or
functions, will not be serialized. Such values in objects will be
dropped; in arrays they will be replaced with null. You can use
a replacer function to replace those with JSON values.
JSON.stringify(undefined) returns undefined.
The optional space parameter produces a stringification of the
value that is filled with line breaks and indentation to make it
easier to read.
If the space parameter is a non-empty string, then that string will
be used for indentation. If the space parameter is a number, then
then indentation will be that many spaces.
Example:
text = JSON.stringify(['e', {pluribus: 'unum'}]);
// text is '["e",{"pluribus":"unum"}]'
text = JSON.stringify(['e', {pluribus: 'unum'}], null, '\t');
// text is '[\n\t"e",\n\t{\n\t\t"pluribus": "unum"\n\t}\n]'
text = JSON.stringify([new Date()], function (key, value) {
return this[key] instanceof Date ?
'Date(' + this[key] + ')' : value;
});
// text is '["Date(---current time---)"]'
JSON.parse(text, reviver)
This method parses a JSON text to produce an object or array.
It can throw a SyntaxError exception.
The optional reviver parameter is a function that can filter and
transform the results. It receives each of the keys and values,
and its return value is used instead of the original value.
If it returns what it received, then the structure is not modified.
If it returns undefined then the member is deleted.
Example:
// Parse the text. Values that look like ISO date strings will
// be converted to Date objects.
myData = JSON.parse(text, function (key, value) {
var a;
if (typeof value === 'string') {
a =
/^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2}(?:\.\d*)?)Z$/.exec(value);
if (a) {
return new Date(Date.UTC(+a[1], +a[2] - 1, +a[3], +a[4],
+a[5], +a[6]));
}
}
return value;
});
myData = JSON.parse('["Date(09/09/2001)"]', function (key, value) {
var d;
if (typeof value === 'string' &&
value.slice(0, 5) === 'Date(' &&
value.slice(-1) === ')') {
d = new Date(value.slice(5, -1));
if (d) {
return d;
}
}
return value;
});
This is a reference implementation. You are free to copy, modify, or
redistribute.
This code should be minified before deployment.
See http://javascript.crockford.com/jsmin.html
USE YOUR OWN COPY. IT IS EXTREMELY UNWISE TO LOAD THIRD PARTY
CODE INTO YOUR PAGES.
*/
/*jslint evil: true */
/*global JSON */
/*members "", "\b", "\t", "\n", "\f", "\r", "\"", JSON, "\\", call,
charCodeAt, getUTCDate, getUTCFullYear, getUTCHours, getUTCMinutes,
getUTCMonth, getUTCSeconds, hasOwnProperty, join, lastIndex, length,
parse, propertyIsEnumerable, prototype, push, replace, slice, stringify,
test, toJSON, toString
*/
if (!this.JSON) {
// Create a JSON object only if one does not already exist. We create the
// object in a closure to avoid global variables.
JSON = function () {
function f(n) {
// Format integers to have at least two digits.
return n < 10 ? '0' + n : n;
}
Date.prototype.toJSON = function (key) {
return this.getUTCFullYear() + '-' +
f(this.getUTCMonth() + 1) + '-' +
f(this.getUTCDate()) + 'T' +
f(this.getUTCHours()) + ':' +
f(this.getUTCMinutes()) + ':' +
f(this.getUTCSeconds()) + 'Z';
};
var cx = /[\u0000\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g,
escapeable = /[\\\"\x00-\x1f\x7f-\x9f\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g,
gap,
indent,
meta = { // table of character substitutions
'\b': '\\b',
'\t': '\\t',
'\n': '\\n',
'\f': '\\f',
'\r': '\\r',
'"' : '\\"',
'\\': '\\\\'
},
rep;
function quote(string) {
// If the string contains no control characters, no quote characters, and no
// backslash characters, then we can safely slap some quotes around it.
// Otherwise we must also replace the offending characters with safe escape
// sequences.
escapeable.lastIndex = 0;
return escapeable.test(string) ?
'"' + string.replace(escapeable, function (a) {
var c = meta[a];
if (typeof c === 'string') {
return c;
}
return '\\u' + ('0000' +
(+(a.charCodeAt(0))).toString(16)).slice(-4);
}) + '"' :
'"' + string + '"';
}
function str(key, holder) {
// Produce a string from holder[key].
var i, // The loop counter.
k, // The member key.
v, // The member value.
length,
mind = gap,
partial,
value = holder[key];
// If the value has a toJSON method, call it to obtain a replacement value.
if (value && typeof value === 'object' &&
typeof value.toJSON === 'function') {
value = value.toJSON(key);
}
// If we were called with a replacer function, then call the replacer to
// obtain a replacement value.
if (typeof rep === 'function') {
value = rep.call(holder, key, value);
}
// What happens next depends on the value's type.
switch (typeof value) {
case 'string':
return quote(value);
case 'number':
// JSON numbers must be finite. Encode non-finite numbers as null.
return isFinite(value) ? String(value) : 'null';
case 'boolean':
case 'null':
// If the value is a boolean or null, convert it to a string. Note:
// typeof null does not produce 'null'. The case is included here in
// the remote chance that this gets fixed someday.
return String(value);
// If the type is 'object', we might be dealing with an object or an array or
// null.
case 'object':
// Due to a specification blunder in ECMAScript, typeof null is 'object',
// so watch out for that case.
if (!value) {
return 'null';
}
// Make an array to hold the partial results of stringifying this object value.
gap += indent;
partial = [];
// If the object has a dontEnum length property, we'll treat it as an array.
if (typeof value.length === 'number' &&
!(value.propertyIsEnumerable('length'))) {
// The object is an array. Stringify every element. Use null as a placeholder
// for non-JSON values.
length = value.length;
for (i = 0; i < length; i += 1) {
partial[i] = str(i, value) || 'null';
}
// Join all of the elements together, separated with commas, and wrap them in
// brackets.
v = partial.length === 0 ? '[]' :
gap ? '[\n' + gap +
partial.join(',\n' + gap) + '\n' +
mind + ']' :
'[' + partial.join(',') + ']';
gap = mind;
return v;
}
// If the replacer is an array, use it to select the members to be stringified.
if (rep && typeof rep === 'object') {
length = rep.length;
for (i = 0; i < length; i += 1) {
k = rep[i];
if (typeof k === 'string') {
v = str(k, value, rep);
if (v) {
partial.push(quote(k) + (gap ? ': ' : ':') + v);
}
}
}
} else {
// Otherwise, iterate through all of the keys in the object.
for (k in value) {
if (Object.hasOwnProperty.call(value, k)) {
v = str(k, value, rep);
if (v) {
partial.push(quote(k) + (gap ? ': ' : ':') + v);
}
}
}
}
// Join all of the member texts together, separated with commas,
// and wrap them in braces.
v = partial.length === 0 ? '{}' :
gap ? '{\n' + gap +
partial.join(',\n' + gap) + '\n' +
mind + '}' :
'{' + partial.join(',') + '}';
gap = mind;
return v;
}
}
// Return the JSON object containing the stringify, parse, and quote methods.
return {
stringify: function (value, replacer, space) {
// The stringify method takes a value and an optional replacer, and an optional
// space parameter, and returns a JSON text. The replacer can be a function
// that can replace values, or an array of strings that will select the keys.
// A default replacer method can be provided. Use of the space parameter can
// produce text that is more easily readable.
var i;
gap = '';
indent = '';
if (space) {
// If the space parameter is a number, make an indent string containing that
// many spaces.
if (typeof space === 'number') {
for (i = 0; i < space; i += 1) {
indent += ' ';
}
// If the space parameter is a string, it will be used as the indent string.
} else if (typeof space === 'string') {
indent = space;
}
}
// If there is a replacer, it must be a function or an array.
// Otherwise, throw an error.
rep = replacer;
if (replacer && typeof replacer !== 'function' &&
(typeof replacer !== 'object' ||
typeof replacer.length !== 'number')) {
throw new Error('JSON.stringify');
}
// Make a fake root object containing our value under the key of ''.
// Return the result of stringifying the value.
return str('', {'': value});
},
parse: function (text, reviver) {
// The parse method takes a text and an optional reviver function, and returns
// a JavaScript value if the text is a valid JSON text.
var j;
function walk(holder, key) {
// The walk method is used to recursively walk the resulting structure so
// that modifications can be made.
var k, v, value = holder[key];
if (value && typeof value === 'object') {
for (k in value) {
if (Object.hasOwnProperty.call(value, k)) {
v = walk(value, k);
if (v !== undefined) {
value[k] = v;
} else {
delete value[k];
}
}
}
}
return reviver.call(holder, key, value);
}
// Parsing happens in four stages. In the first stage, we replace certain
// Unicode characters with escape sequences. JavaScript handles many characters
// incorrectly, either silently deleting them, or treating them as line endings.
cx.lastIndex = 0;
if (cx.test(text)) {
text = text.replace(cx, function (a) {
return '\\u' + ('0000' +
(+(a.charCodeAt(0))).toString(16)).slice(-4);
});
}
// In the second stage, we run the text against
// regular expressions that look for non-JSON patterns. We are especially
// concerned with '()' and 'new' because they can cause invocation, and '='
// because it can cause mutation. But just to be safe, we want to reject all
// unexpected forms.
// We split the second stage into 4 regexp operations in order to work around
// crippling inefficiencies in IE's and Safari's regexp engines. First we
// replace all backslash pairs with '@' (a non-JSON character). Second, we
// replace all simple value tokens with ']' characters. Third, we delete all
// open brackets that follow a colon or comma or that begin the text. Finally,
// we look to see that the remaining characters are only whitespace or ']' or
// ',' or ':' or '{' or '}'. If that is so, then the text is safe for eval.
if (/^[\],:{}\s]*$/.test(text.replace(/\\["\\\/bfnrtu]/g, '@').
replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']').
replace(/(?:^|:|,)(?:\s*\[)+/g, ''))) {
// In the third stage we use the eval function to compile the text into a
// JavaScript structure. The '{' operator is subject to a syntactic ambiguity
// in JavaScript: it can begin a block or an object literal. We wrap the text
// in parens to eliminate the ambiguity.
j = eval('(' + text + ')');
// In the optional fourth stage, we recursively walk the new structure, passing
// each name/value pair to a reviver function for possible transformation.
return typeof reviver === 'function' ?
walk({'': j}, '') : j;
}
// If the text is not JSON parseable, then a SyntaxError is thrown.
throw new SyntaxError('JSON.parse');
}
};
}();
}
!usage
{{{[img[mailator.png]]}}}
[img[mailator.png]]
!notes
attached by FileDropPlugin
!type
image/png
!file
!url
!hiddenData
/%
!data

!endHiddenData
%/
var a=['a','b'];
var b=JSON.stringify(a);
typeof a
typeof b
var c = JSON.parse(b);
typeof c
//Passes through eval(), so may not work on some functions.// [[print_r2]]
<html>
<form class="eval" style="display:inline;margin:0;padding:0;white-space:nowrap;"
action="#" onsubmit="
//print_r( obj, maxLevel, maxStringLength, boolSkipMethodsAndFunctions, separator, startLevel???, strCallback )
function print_r(x, max, sMax, skipMethods, sep, l, strCallback) {
max = max || 10;
sMax = sMax || 50;
skipMethods = skipMethods || true;
sep = sep || ' ';
l = l || 0;
if (l > max) return '<font color=\'green\'>[Stopped at ' + l + ' levels]</font><br>\n';
var i, r = '', t = typeof x, tab = '';
if (x === null)
r += '(null)<br>\n';
else if (t == 'object') {
l++;
for (i = 0; i < l; i++)
tab += sep;
if (x && x.length)
t = 'array';
r += '(' + t + ':' + l + ') : <br>\n';
for (i in x) {
if (!(typeof x[i] == 'function' && skipMethods)) {
try {
r += tab + '[' + i + '] : ' +
print_r(x[i], max, sMax, skipMethods, sep, l, strCallback);
}
catch (e) {
return r+='<font color=\'red\'>[ERROR: ' + e + ']</font><br>\n';
}
}
}
}
else {
var sLen = '';
if (t == 'string') {
sLen = '[' + x.length + ']';
if (x.length > sMax)
x = x.substr(0, sMax) + '...';
if(strCallback)
x = strCallback(x);
}
if (!(t == 'function' && skipMethods)) {
r += '(' + t + sLen + ') ' + x + '<br>\n';
}
}
return r;
};
function strCB(str){
return str;
};
(document.getElementById('outprintr').innerHTML) =
('\n<p>' + print_r(eval(document.getElementById('inprintr').value),3) + '</p>');
// ('\n<p>' + print_r(eval(document.getElementById('inprintr').value),3,50,true,null,null, strCB) + '</p>');
//print_r( obj, maxLevel, maxStringLength, boolSkipMethodsAndFunctions, separator, startLevel???, strCallback )
">
<input type=text id="inprintr" style="width:80%" value="document.location;"
onkeydown="if(event.keyCode==13){this.form.onsubmit(); return false;}" />
<input type=reset value="Clear" style="width:4em" onclick="
document.getElementById('outprintr').innerHTML='';this.form.input.focus()" />
<input type=button value="eval" style="width:4em" onclick="this.form.onsubmit()" />
</form>
<div id='outprintr' style="background-color:WhiteSmoke !important;"></div>
</html>
//Requires [[InlineJavascriptPlugin]]//
<html><div id='outprintr2' style="background-color:WhiteSmoke !important;"></div></html>
<script show>
//(document.getElementById('outprintr2').innerHTML) = print_r(document.location,2);
(document.getElementById('outprintr2').innerHTML) = print_r(document.location ,2);
//print_r( obj, maxLevel, maxStringLength, boolSkipMethodsAndFunctions, separator, startLevel??? ,strCallback )
function print_r(x, max, sMax, skipMethods, sep, l, strCallback) {
max = max || 10;
sMax = sMax || 50;
skipMethods = skipMethods || true;
sep = sep || ' ';
l = l || 0;
if (l > max) return '<font color=\'green\'>[Stopped at ' + l + ' levels]</font><br>\n';
var i, r = '', t = typeof x, tab = '';
if (x === null)
r += '(null)<br>\n';
else if (t == 'object') {
l++;
for (i = 0; i < l; i++)
tab += sep;
if (x && x.length)
t = 'array';
r += '(' + t + ':' + l + ') : <br>\n';
for (i in x) {
if (!(typeof x[i] == 'function' && skipMethods)) {
try {
r += tab + '[' + i + '] : ' +
print_r(x[i], max, sMax, skipMethods, sep, l, strCallback);
}
catch (e) {
return r+='<font color=\'red\'>[ERROR: ' + e + ']</font><br>\n';
}
}
}
}
else {
var sLen = '';
if (t == 'string') {
sLen = '[' + x.length + ']';
if (x.length > sMax)
x = x.substr(0, sMax) + '...';
if(strCallback)
x = strCallback(x);
}
if (!(t == 'function' && skipMethods)) {
r += '(' + t + sLen + ') ' + x + '<br>\n';
}
}
return r;
};
function strCB(str){
return str;
};
</script>
!usage
{{{[img[readOnly.png]]}}}
[img[readOnly.png]]
!notes
attached by FileDropPlugin
!type
image/png
!file
!url
!hiddenData
/%
!data

!endHiddenData
%/
//{{{
({revisions:{'14018e61-be1e-48d3-9ade-0dae3c9cb5dd':{alive:{'8b35aace-2080-40fd-a42f-8c853dd96622':"487400c2-9002-4d6f-8ae5-500e1ad2e1ad"}, dead:{}, changed:["8b35aace-2080-40fd-a42f-8c853dd96622"], branch:null, timestamp:1278280085307, metadata:{subject:"First Draft"}, directParent:null, additionalParent:null}, 'fb1ad628-cb39-4554-9f23-8ac874739534':{alive:{'8b35aace-2080-40fd-a42f-8c853dd96622':"255e851b-2e55-499d-83c8-84f5f1a5c25f"}, dead:{}, changed:["8b35aace-2080-40fd-a42f-8c853dd96622"], branch:null, timestamp:1278280109681, metadata:{subject:"Second Draft"}, directParent:"14018e61-be1e-48d3-9ade-0dae3c9cb5dd", additionalParent:null}, 'e8d230d3-da59-43b5-8fb2-9f2c22c966fa':{alive:{'8b35aace-2080-40fd-a42f-8c853dd96622':"a6b83261-d904-4729-99e4-2c0fd4705057"}, dead:{}, changed:["8b35aace-2080-40fd-a42f-8c853dd96622"], branch:null, timestamp:1278280138897, metadata:{subject:"Third Draft"}, directParent:"fb1ad628-cb39-4554-9f23-8ac874739534", additionalParent:null}, '51a8fbbe-d629-4934-aebf-a06b9fddfaf2':{alive:{'8b35aace-2080-40fd-a42f-8c853dd96622':"c6e227c5-94c8-4a0c-b131-8b4e7a9298ff"}, dead:{}, changed:["8b35aace-2080-40fd-a42f-8c853dd96622"], branch:null, timestamp:1278280191624, metadata:{subject:"1B"}, directParent:"14018e61-be1e-48d3-9ade-0dae3c9cb5dd", additionalParent:null}}, bodies:{'487400c2-9002-4d6f-8ae5-500e1ad2e1ad':{title:"historyPluginSample", text:"<<history>>First Draft:\nThis is the first draft. lalalalalala", modifier:"KennyZ", modified:1278280077866, tags:"sample"}, '255e851b-2e55-499d-83c8-84f5f1a5c25f':{title:"historyPluginSample", text:"<<history>>Second Draft:\nThis is the second draft. bahahahahahaha", modifier:"KennyZ", modified:1278280102962, tags:"sample"}, 'a6b83261-d904-4729-99e4-2c0fd4705057':{title:"historyPluginSample", text:"<<history>>Third Draft:\nThis is the third draft. muhahahahaha", modifier:"KennyZ", modified:1278280133879, tags:"sample"}, 'c6e227c5-94c8-4a0c-b131-8b4e7a9298ff':{title:"historyPluginSample", text:"<<history>>First Draft B:\nThis is the first draft (version B).\nShould I say lala, baba, or haha?", modifier:"KennyZ", modified:1278280180431, tags:"sample"}}})
//}}}
//{{{
({revisions:{'d982ba48-d5e7-4dd3-a282-3cdc5340d320':{alive:{'96317a1d-b01c-49a0-8552-9c45a8ccea8b':"d37dd945-0a10-448f-94bc-44b16be6cec5"}, dead:{}, changed:["96317a1d-b01c-49a0-8552-9c45a8ccea8b"], branch:null, timestamp:1278305739373, metadata:{subject:"abc"}, directParent:null, additionalParent:null}, '9e9ad1b5-c6ab-4f56-9ab6-b5f3fe1c4598':{alive:{'96317a1d-b01c-49a0-8552-9c45a8ccea8b':"c9cb13c1-6d49-434e-b6a0-578d3a06524d"}, dead:{}, changed:["96317a1d-b01c-49a0-8552-9c45a8ccea8b"], branch:null, timestamp:1278305754348, metadata:{subject:"bbb"}, directParent:"d982ba48-d5e7-4dd3-a282-3cdc5340d320", additionalParent:null}, '50a0a0a2-d507-4960-a161-ad6b7c8507bc':{alive:{'96317a1d-b01c-49a0-8552-9c45a8ccea8b':"78b80f84-bbde-4726-8b29-706fef7d3333"}, dead:{}, changed:["96317a1d-b01c-49a0-8552-9c45a8ccea8b"], branch:null, timestamp:1278305763150, metadata:{subject:"ccccc"}, directParent:"9e9ad1b5-c6ab-4f56-9ab6-b5f3fe1c4598", additionalParent:null}, '12952761-b14f-4c32-a40e-94de7f0ccf78':{alive:{'96317a1d-b01c-49a0-8552-9c45a8ccea8b':"51bcaf5b-7a35-4b8c-9832-8ac197dfb1b5"}, dead:{}, changed:["96317a1d-b01c-49a0-8552-9c45a8ccea8b"], branch:null, timestamp:1278305892436, metadata:{subject:"ddddd"}, directParent:"50a0a0a2-d507-4960-a161-ad6b7c8507bc", additionalParent:null}, '59fdb75f-80ec-4018-9e4f-3ec1cd49664c':{alive:{'96317a1d-b01c-49a0-8552-9c45a8ccea8b':"576864cd-87ed-42e0-9bc2-5c8a642debb9"}, dead:{}, changed:["96317a1d-b01c-49a0-8552-9c45a8ccea8b"], branch:null, timestamp:1278308057287, metadata:{subject:"zz"}, directParent:"d982ba48-d5e7-4dd3-a282-3cdc5340d320", additionalParent:null}}, bodies:{'d37dd945-0a10-448f-94bc-44b16be6cec5':{title:"testzz", text:"<<history>> abc abc abc", modifier:"KennyZ", modified:1278305733358, tags:""}, 'c9cb13c1-6d49-434e-b6a0-578d3a06524d':{title:"testzz", text:"<<history>>bbbbbbbbbbbbbbbbbb", modifier:"KennyZ", modified:1278305750790, tags:""}, '78b80f84-bbde-4726-8b29-706fef7d3333':{title:"testzz", text:"<<history>>cccccccccccc", modifier:"KennyZ", modified:1278305758977, tags:""}, '51bcaf5b-7a35-4b8c-9832-8ac197dfb1b5':{title:"testzz", text:"<<history>>cccccccccccc", modifier:"KennyZ", modified:1278305700000, tags:""}, '576864cd-87ed-42e0-9bc2-5c8a642debb9':{title:"testzz", text:"<<history>> abc abc abc\nas\nf\nasf\nasf", modifier:"KennyZ", modified:1278308046415, tags:""}}})
//}}}
//{{{
({revisions:{'7fa9b899-5379-4fca-92bf-c88bd69e68a1':{alive:{'a7532004-be1d-447e-b45c-014e6821c981':"0deac4fa-e0c0-4137-9115-c96007f8ca8c"}, dead:{}, changed:["a7532004-be1d-447e-b45c-014e6821c981"], branch:null, timestamp:1278361913474, metadata:{subject:"Alpha"}, directParent:null, additionalParent:null}}, bodies:{'0deac4fa-e0c0-4137-9115-c96007f8ca8c':{title:"HistoryPlugin", text:"/***\n<<history>>\n|''Name:''|HistoryPlugin|\n|''Description:''|Add history or revision control to any individual tiddler.|\n|''Author:''|MartinBudden, TonyGarnockJones, and Kenny Z|\n|''Source:''|http://cooltool.tiddlyspot.com/#HistoryPlugin|\n|''Dependencies:''|[[json2]] [[graph]] [[fs]] [[Draw]] [[diff]]|\n|''CodeRepository:''|[[HistoryPluginRequired.zip|http://cooltool.tiddlyspot.com/#HistoryPluginRequired.zip]],|\n|''Version:''|0.0.1|\n|''Status:''|Alpha|\n|''Date:''|July 3, 2010|\n|''Comments:''|[[The original code|http://homepages.kcbbs.gen.nz/tonyg/projects/synchrotron.html]] keeps track of changes to the entire TW. I changed it so each tiddler has its own repository. This gives it that timeline or \"history\" functionality I was going for.|\n|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]] |\n|''~CoreVersion:''|2.6|\n!!Description\nAdd history or revision control to any individual tiddler. Be able to check for changes in different revisions.\n!!Usage\n#Import\n#Save & Reload\n#Add {{{<<history>>}}} to any tiddler.\n#Click commit button after writing first draft.\n!Todo\n*Find and remove rogue revision repositories.\n!!Code\n***/\n//{{{\nif(!version.extensions.HistoryPlugin) {\nversion.extensions.HistoryPlugin= {installed:true};\n\nconfig.macros.history={\ncanvis: [],\ninit: function(){\n\tconfig.shadowTiddlers.StyleSheetForHistory = this.css;\n\tsetStylesheet(store.getTiddlerText(\"StyleSheetForHistory\",this.css),\"history\");\n},\nhandler: function(place,macroName,params,wikifier,paramString,tiddler){\n\tvar rev = new Revision(tiddler);\n\tvar div=createTiddlyElement(place,'div',null,'history');\n\tDrawDvcs.tiddlyRenderRepository(div,rev.repo,rev);\n\tcreateTiddlyElement(div,'br');\n\tif(rev.dirty)\n\t\tcreateTiddlyButton(div,\"commit\",\"Commit the change\",function(){rev.commit()});\n\tif(this.canvis[rev.inode])\n\t\tcreateTiddlyButton(div,\"canvis\",\"Temporary unsaved changes\",\n\t\t\tfunction(){\n\t\t\t\tif(rev.dirty){ //clone & swap\n\t\t\t\t\ttemp = config.macros.history.copy(tiddler.text,tiddler.fields.hist_uuid);\n\t\t\t\t\ttiddler.text=config.macros.history.canvis[rev.inode].text;\n\t\t\t\t\ttiddler.fields.hist_uuid=config.macros.history.canvis[rev.inode].uuid;\n\t\t\t\t\tconfig.macros.history.canvis[rev.inode]=temp;\n\t\t\t\t}else{\n\t\t\t\t\ttiddler.text = config.macros.history.canvis[rev.inode].text;\n\t\t\t\t\ttiddler.fields.hist_uuid = config.macros.history.canvis[rev.inode].uuid;\n\t\t\t\t\tconfig.macros.history.canvis[rev.inode] = null;\n\t\t\t\t}\n\t\t\t\tstory.refreshTiddler(tiddler.title,null,true);\n\t\t\t});\n\treturn false;\n},\ncopy: function(text,uuid){\n\tt={}; t.text=text; t.uuid=uuid; return t;\n},\ncss: \"div.history{float:right; margin:4px;}\\n\\\ndiv.repository{line-height:0px;white-space:nowrap;}\\n\\\n.revision.selected{background-color:blue;color:white;}\\n\\\n.revision.modified{background-color:red;color:white;}\\n\",\n//.revision.aParent{background-color:#00cc00;color:white;}\\n\", // NEVER USED\n};\n// draw diagram of revision paths\nDrawDvcs.tiddlyRenderRepository = function(place,repo,revStore) {\n\tvar para=createTiddlyElement(place,'div',null,'repository');\n\tvar ordering = DrawDvcs.renderRepository(repo);\n\tfor (var i = 0; i < ordering.length; i++){\n\t\tvar item = ordering[i];\n\t\tvar rev = repo.lookupRev(item.revId);\n\t\tvar pictures = item.pictures;\n\t\tfor (var j = 0; j < pictures.length; j++) {\n\t\t\timg=createTiddlyElement(para,'img',null,'repoImg');\n\t\t\timg.src = config.macros.history.images[pictures[j]];\n\t\t}\n\t\tvar summary=((rev.metadata||{}).subject)||\"Untitled\";\n\t\tvar btnCss='revision'; var btnTxt='Checkout';\n\t\tif(revStore.fs.directParent==item.revId){\n\t\t\tif(revStore.dirty) btnCss+=' modified';\n\t\t\telse btnCss+=' selected';\n\t\t\tbtnTxt='Revert';\n\t\t}//else if(revStore.fs.additionalParent == item.revId) btnCss+=' aParent'; // NEVER HAPPENS\n\t\tvar s=createTiddlyButton(para,summary,btnTxt,revisionClicked,btnCss);\n\t\ts.revisionId=item.revId; s.revStore=revStore;\n\t\tcreateTiddlyElement(para,'br');\n\t}\n};\n// called when a revision path is clicked\nfunction revisionClicked(event) {\n\tvar e = (event || window.event);\n\tvar revId = e.target.revisionId;\n\tvar revStore = e.target.revStore;\n\trevStore.checkout(revId);\n\treturn false;\n};\n// object holding revisions\nfunction Revision(tiddler){\n\tthis.repo = new Dvcs.Repository();\n\tthis.fs = this.repo.update(null);\n\tthis.tiddler = tiddler;\n\tthis.inode = tiddler.fields.hist_inode;\n\tthis.uuid = tiddler.fields.hist_uuid;\n\tthis.dirty=false;\n\tthis.loadRepo();\n\tthis.hasChanged();\n\treturn this;\n};\n// convert data saved in tiddler into repo\nRevision.prototype.loadRepo = function(){\n\tvar repoText = store.getTiddlerText(\"repo_\"+this.inode,null);\n if (repoText){\n\t\tthis.repo.importRevisions(eval(repoText));\n\t\tthis.fs=this.repo.update(this.uuid);\n }else{\n\tvar id=this.fs.createFile();\n\twhile(store.tiddlerExists(\"repo_\"+id)){\n\t\tid=this.fs.createFile();\n\t}\n\tthis.inode = this.tiddler.fields.hist_inode = id;\n }\n};\n// save changes into repo\nRevision.prototype.commit = function(){\n\tif(!this.dirty)return;\n\tnote = prompt(\"Note this commit: \").substr(0,40); // error if null and returns.\n\tthis.fs.setProp(this.inode,\"title\",this.tiddler.title);\n\tthis.fs.setProp(this.inode,\"text\",this.tiddler.text);\n\tthis.fs.setProp(this.inode,\"modifier\",this.tiddler.modifier);\n\tthis.fs.setProp(this.inode,\"modified\",this.tiddler.modified.getTime());\n\ttags=[];for(i=0;i<this.tiddler.tags.length;i++)\n\t\ttags.push(String.encodeTiddlyLink(this.tiddler.tags[i]));\n\tthis.fs.setProp(this.inode,\"tags\",tags.join(' '));\n\tthis.fs.anyDirty=true;\n\tuuid = this.repo.commit(this.fs,{subject: note});\n\tthis.uuid = this.tiddler.fields.hist_uuid = uuid;\n\tthis.fs = this.repo.update(uuid);\n\tthis.saveRepo();\n\tstory.refreshTiddler(this.tiddler.title,null,true);\n};\n//save repo into a tiddler\nRevision.prototype.saveRepo = function(){\n\ttitle = \"repo_\"+this.inode;\n\trepoText = uneval(this.repo.exportRevisions());\n\ttext = '//{{{\\n'+repoText+'\\n//}}}\\n';\n\ttags = ['excludeLists','excludeSearch','repository'];\n\tstore.saveTiddler(title,title,text,this.tiddler.title,new Date(),tags);\n\tautoSaveChanges();\n};\n//get diff between current text and data in repo\nRevision.prototype.hasChanged = function(){\n\t// check text body\n\ttxt = Crypto.hexSha1Str(this.tiddler.text);\n\tsrc = Crypto.hexSha1Str(this.fs.getProp(this.inode,\"text\",\"\"));\n\tif(txt!=src)return this.dirty=true;\n\t// check title\n\ttxt = Crypto.hexSha1Str(this.tiddler.title);\n\tsrc = Crypto.hexSha1Str(this.fs.getProp(this.inode,\"title\",\"\"));\n\treturn this.dirty=(txt!=src);\n};\n// take out data from repo\nRevision.prototype.checkout = function(uuid){\n\tif(this.dirty){\n\t\tif(config.macros.history.canvis[this.inode])\n\t\t\tif(!confirm(\"Any uncommitted work would be lost. Are you sure?\"))\n\t\t\t\treturn false;\n\t\tconfig.macros.history.canvis[this.inode]=\n\t\t\tconfig.macros.history.copy(this.tiddler.text,this.uuid);\n\t}\n\tthis.uuid = this.tiddler.fields.hist_uuid = uuid;\n\tthis.fs = this.repo.update(this.uuid);\n\tthisTitle=this.tiddler.title;\n\ttitle=this.fs.getProp(this.inode,\"title\",thisTitle);\n\ttext=this.fs.getProp(this.inode,\"text\",\"\");\t\n\twho=this.fs.getProp(this.inode,\"modifier\",\"UNKNOWN\");\n\twhen=this.fs.getProp(this.inode,\"modified\",new Date().getTime());\n\tdate=new Date(); date.setTime(parseInt(when));\n\ttags=this.fs.getProp(this.inode,\"tags\",' ').readBracketedList();\n\tif(title != thisTitle){\n\t\tfor(i=1,s=title;store.tiddlerExists(title);i++){\n\t\t\ttitle=s+' ('+i+')';\n\t\t}\n\t\tstory.closeTiddler(thisTitle,false,false); \t\t\n\t\tstore.saveTiddler(thisTitle,title,text,who,date,tags,this.tiddler.fields);\n\t\tstory.displayTiddler(null,title);\n\t}else this.tiddler.set(null,text,who,date,tags);\n\tstory.refreshTiddler(title,null,true);\n\treturn true;\n};\n\nconfig.macros.history.images = {\n \"blob_0.png\": \"\"\n ,\"blob_1.png\": \"\"\n ,\"blob_10.png\": \"\"\n ,\"blob_11.png\": \"\"\n ,\"blob_12.png\": \"\"\n ,\"blob_13.png\": \"\"\n ,\"blob_14.png\": \"\"\n ,\"blob_15.png\": \"\"\n ,\"blob_2.png\": \"\"\n ,\"blob_3.png\": \"\"\n ,\"blob_4.png\": \"\"\n ,\"blob_5.png\": \"\"\n ,\"blob_6.png\": \"\"\n ,\"blob_7.png\": \"\"\n ,\"blob_8.png\": \"\"\n ,\"blob_9.png\": \"\"\n ,\"slide_l.png\": \"\"\n ,\"slide_m.png\": \"\"\n ,\"slide_r.png\": \"\"\n ,\"stick_0.png\": \"\"\n ,\"stick_1.png\": \"\"\n ,\"stick_10.png\": \"\"\n ,\"stick_11.png\": \"\"\n ,\"stick_12.png\": \"\"\n ,\"stick_13.png\": \"\"\n ,\"stick_14.png\": \"\"\n ,\"stick_15.png\": \"\"\n ,\"stick_2.png\": \"\"\n ,\"stick_3.png\": \"\"\n ,\"stick_4.png\": \"\"\n ,\"stick_5.png\": \"\"\n ,\"stick_6.png\": \"\"\n ,\"stick_7.png\": \"\"\n ,\"stick_8.png\": \"\"\n ,\"stick_9.png\": \"\"\n};\n} //# end of 'install only once'\n//}}}", modifier:"KennyZ", modified:1278361877193, tags:"systemConfig commented"}}})
//}}}
//{{{
({revisions:{'619c2f33-ab23-4a0d-b277-73de9ce7e11d':{alive:{'d8649584-cb1b-49e5-9c11-be9e64bae7a5':"e8a0df8c-c225-405c-81a6-376c44b68eb0"}, dead:{}, changed:["d8649584-cb1b-49e5-9c11-be9e64bae7a5"], branch:null, timestamp:1278435451167, metadata:{subject:"+IncludeForm"}, directParent:null, additionalParent:null}}, bodies:{'e8a0df8c-c225-405c-81a6-376c44b68eb0':{title:"QuickLog", text:"<<history>>\n/%\n!info\nNote: Changes are not saved.\n{{{<<tiddler QuickLog with: Title_YYYY-0MM-0DD \"tagname\" \"singleLine\" \"separator\" \"timeStamp\">>}}}\n{{{<<tiddler QuickLog with: Worklog_YYYY-0MM-0DD \"worklog\" \"checked\" \"\" \"checked\">>}}}\n<<tiddler QuickLog with: Worklog_YYYY-0MM-0DD \"worklog\" \"\" \"\" \"\">>\n//Shortcut: Press {{{SHIFT}}} + {{{ENTER}}} to save.//\n!end\n\n!show\n<html>\n<form class=\"QuickLog\" name=\"$1\" style=\"display:inline;margin:0;padding:0;white-space:nowrap;\"\naction=\"#\" onsubmit=\"function save(){\n var when=new Date();\n var title=when.formatString('$1');\n var tags='$2';\n var who=config.options.txtUserName;\n\n var text=txt.value.replace(/^\\s+|\\s+$/g, ''); if(text=='') return;\n if(singleLine.checked) text=text.replace(/\\s+/gm, ' ');\n if(timeStamp.checked) text='~~:::::__'+when+'__:::::~~\\n'+text;\n\n if(!store.tiddlerExists(title)){\n if(includeForm.checked)\n text='<<tiddler QuickLog with: '+title+' '+tags+' \\'$3\\' \\'$4\\' \\'$5\\'>>\\n!\\n' + text;\n store.saveTiddler(title,title,text,who,when,tags);\n story.displayTiddler(null,title);\n }else{\n var tiddler = store.getTiddler(title);\n if(separator.checked) tiddler.text += '\\n----';\n tiddler.text += '\\n'+ text;\n //store.saveTiddler(title,title,text,who,when,tags);\n store.dirty=true;\n story.refreshTiddler(title,DEFAULT_VIEW_TEMPLATE,true);\n }\n autoSaveChanges(); txt.value=''; txt.focus();\n}; save();\">\n<input type=reset value=\"Clear\" style=\"width:4em\" onclick=\"this.form.txt.focus()\" />\n<input type=button value=\"Post\" style=\"width:4em\" onclick=\"this.form.onsubmit();\" />\n<span title=\"Single Line\"><input type=\"checkbox\" name=\"singleLine\" $3>SL</input></span>\n<span title=\"Separator\"><input type=\"checkbox\" name=\"separator\" $4>HR</input></span>\n<span title=\"Time Stamp\"><input type=\"checkbox\" name=\"timeStamp\" $5>TS</input></span>\n<span title=\"Include Form\"><input type=\"checkbox\" name=\"includeForm\" $6>IF</input></span><br />\n<textarea name=\"txt\" rows=\"5\" cols=\"60\" style=\"width:90%\" onkeydown=\"\n\tif(event.keyCode == 16) isShift =true;\n\tif(isShift==true && event.keyCode == 13){ this.form.onsubmit(); return false;}\n\" onkeyup=\"isShift=false\"></textarea>\n</form></html>\n!end\n%/<<tiddler {{'QuickLog##'+('$1'=='$'+'1'?'info':'show')}} with: [[$1]] {{'$2'!='$'+'2'?'$2':''}} {{'$3'!='$'+'3'?'$3':''}} {{'$4'!='$'+'4'?'$4':''}} {{'$5'!='$'+'5'?'$5':''}} {{'$6'!='$'+'6'?'$6':''}}>>", modifier:"KennyZ", modified:1278435444525, tags:"transclusion"}}})
//}}}
It is a mistake to regard age as a downhill grade toward dissolution. The reverse is true. As one grows older, one climbs with surprising strides.
//George Sand (1804 - 1876)//
----
Man is the only animal whose desires increase as they are fed; the only animal that is never satisfied.
//Henry George (1839 - 1897)//
----
The sole advantage of power is that you can do more good.
//Baltasar Gracian, The Art of Worldly Wisdom, 1647//
----
The family is changing not disappearing. We have to broaden our understanding of it, look for the new metaphors.
//Mary Catherine Bateson//
----
Far better to think historically, to remember the lessons of the past. Thus, far better to conceive of power as consisting in part of the knowledge of when not to use all the power you have. Far better to be one who knows that if you reserve the power not to use all your power, you will lead others far more successfully and well.
A. Bartlett Giamatti (1938 - 1989), President of Yale University
----
Nearly all men can stand adversity, but if you want to test a man's character, give him power.
Abraham Lincoln (1809 - 1865)
----
You see what power is - holding someone else's fear in your hand and showing it to them!
Amy Tan (1952 - )
----
The sole advantage of power is that you can do more good.
Baltasar Gracian, The Art of Worldly Wisdom, 1647
----
To know the pains of power, we must go to those who have it; to know its pleasures, we must go to those who are seeking it.
Charles Caleb Colton (1780 - 1832), Lacon, 1825
----
It is said that power corrupts, but actually it's more true that power attracts the corruptible. The sane are usually attracted by other things than power.
David Brin (1950 - )
----
Let not thy will roar, when thy power can but whisper.
Dr. Thomas Fuller (1654 - 1734), Gnomologia, 1732
----
Ultimately, the only power to which man should aspire is that which he exercises over himself.
Elie Wiesel (1928 - )
----
It is when power is wedded to chronic fear that it becomes formidable.
Eric Hoffer (1902 - 1983), The Passionate State of Mind, 1954
----
If absolute power corrupts absolutely, does absolute powerlessness make you pure?
Harry Shearer
----
The great secret of power is never to will to do more than you can accomplish.
Henrik Ibsen (1828 - 1906)
----
Be fit for more than the thing you are now doing. Let everyone know that you have a reserve in yourself; that you have more power than you are now using. If you are not too large for the place you occupy, you are too small for it.
James A. Garfield (1831 - 1881)
----
Power corrupts. Absolute power is kind of neat.
John Lehman (1942 - ), Secretary of the Navy, 1981-1987
----
One person with a belief is equal to a force of 99 who have only interests.
John Stuart Mill (1806 - 1873)
----
The secret of all power is - save your force. If you want high pressure you must choke off waste.
Joseph Farrell
----
If power was an illusion, wasn't weakness necessarily one also?
Lois McMaster Bujold, A Civil Campaign, 1999
----
Power tends to corrupt, and absolute power corrupts absolutely.
Lord Acton, Letter to Bishop Mandell Creighton, 1887
----
The highest proof of virtue is to possess boundless power without abusing it.
Lord Macaulay, review of Lucy Aikin, 'Life and Writings of Addison,' 1943
----
Power never takes a back step - only in the face of more power.
Malcolm X (1925 - 1965), Malcolm X Speaks, 1965
----
The problem of power is how to achieve its responsible use rather than its irresponsible and indulgent use - of how to get men of power to live for the public rather than off the public.
Robert F. Kennedy (1925 - 1968), 'I Remember, I Believe,' The Pursuit of Justice, 1964
----
Most powerful is he who has himself in his own power.
Seneca (5 BC - 65 AD)
----
Knowledge is power.
Sir Francis Bacon (1561 - 1626), Religious Meditations, Of Heresies, 1597
----
We thought, because we had power, we had wisdom.
Stephen Vincent Benet (1898 - 1943), Litany for Dictatorships, 1935
----
We have, I fear, confused power with greatness.
Stewart L. Udall (1920 - ), commencement address, Dartmouth College, June 13, 1965
----
An honest man can feel no pleasure in the exercise of power over his fellow citizens.
Thomas Jefferson (1743 - 1826), letter to John Melish, January 13, 1813
----
The love of liberty is the love of others; the love of power is the love of ourselves.
William Hazlitt (1778 - 1830)
----
Power consists in one's capacity to link his will with the purpose of others, to lead by reason and a gift of cooperation.
Woodrow Wilson (1856 - 1924), letter to Mary A. Hulbert, September 21, 1913
in FF, works on textarea only
//{{{
function makeitbold(){
var $tb = document.getElementById("textbox");
if (document.selection){
var str=document.selection.createRange().text;
var sel=document.selection.createRange();
sel.text="<b>"+str+"</b>";
}else if (typeof $tb.selectionStart != 'undefined'){
var $before, $after, $selection;
$before= $tb.value.substring(0, $tb.selectionStart)
$selection = $tb.value.substring($tb.selectionStart, $tb.selectionEnd)
$after = $tb.value.substring($tb.selectionEnd, $tb.value.length)
$tb.value= String.concat($before, "<b>", $selection, "</b>", $after)
}
$tb.focus();
}
//}}}
!usage
{{{[[syntaxhighlighterplugin4tiddlywiki|syntaxhighlighterplugin4tiddlywiki]]}}}
[[syntaxhighlighterplugin4tiddlywiki|syntaxhighlighterplugin4tiddlywiki]]
!notes
attached by FileDropPlugin
!type
application/x-zip-compressed
!file
!url
!hiddenData
/%data:application/x-zip-compressed;base64,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
%/
You can suggest a series of articles about neighborhood
restaurants or bars, or a feature about local bookstores,
hairdressing and cosmetic salons. You can even include your
family and friends in your research. Ask them where they
shop and why. Don't forget the seasonal markets; First
Communions, Bar Mitzvahs, June weddings, Easter and
Christmas Fairs. Is a local celebrity about to get married?
Do certain stores have seasonal promotions planned? You can
almost research...
Robert Norris paced the small living room, stabbing at the air with the sheaf of papers clenched in his fist.
"Look. This is crazy."
"What do you mean, crazy?"
"I mean that you can't do it!"
"I can and I will."
"No way!"
"Nothing you say will stop me."
"Fool!"
zzz[[wc ex2 w50,L8]]<br>XXXXX<br>[[wc ex1 w74,L9]]zzz
a あ ア か カ さ サ た タ な ナ は ハ ま マ や ヤ ら ラ わ ワ
i い イ き キ し シ ち チ に ニ ひ ヒ み ミ * り リ ゐ ヰ
u う ウ く ク す ス つ ツ ぬ ヌ ふ フ む ム ゆ ユ る ル ん ン
e え エ け ケ せ セ て テ ね ネ へ ヘ め メ * れ レ ゑ ヱ
o お オ こ コ そ ソ と ト の ノ ほ ホ も モ よ ヨ ろ ロ を ヲ
!usage
{{{[img[wordCount.png]]}}}
[img[wordCount.png]]
!notes
attached by FileDropPlugin
!type
image/png
!file
!url
!hiddenData
/%
!data

!endHiddenData
%/