Background: #fff
Foreground: #000
PrimaryPale: #8cf
PrimaryLight: #18f
PrimaryMid: #04b
PrimaryDark: #014
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
/*{{{*/
body {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

hr {height:1px;}

a {text-decoration:none;}

dt {font-weight:bold;}

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

.txtOptionInput {width:11em;}

#contentWrapper .chkOptionInput {border:0;}

.externalLink {text-decoration:underline;}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.whenBackstage {display:none;}
.backstageVisible .whenBackstage {display:block;}
/*}}}*/
/***
StyleSheet for use when a translation requires any css style changes.
This StyleSheet can be used directly by languages such as Chinese, Japanese and Korean which use a logographic writing system and need larger font sizes.
***/

/*{{{*/
body {font-size:0.8em;}

#sidebarOptions {font-size:1.05em;}
#sidebarOptions a {font-style:normal;}
#sidebarOptions .sliderPanel {font-size:0.95em;}

.subtitle {font-size:0.8em;}

.viewer table.listView {font-size:0.95em;}

.htmlarea .toolbarHA table {border:1px solid ButtonFace; margin:0em 0em;}
/*}}}*/
/*{{{*/
@media print {
#mainMenu, #sidebar, #messageArea, .toolbar, #backstageButton, #backstageArea {display: none ! important;}
#displayArea {margin: 1em 1em 0em 1em;}
/* Fixes a feature in Firefox 1.5.0.2 where print preview displays the noscript content */
noscript {display:none;}
}
/*}}}*/
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<div class='headerShadow'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
<div class='headerForeground'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
</div>
<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
<div id='sidebar'>
<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>
<div id='sidebarTabs' refresh='content' force='true' tiddler='SideBarTabs'></div>
</div>
<div id='displayArea'>
<div id='messageArea'></div>
<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->
<!--{{{-->
<div class='toolbar' macro='toolbar closeTiddler closeOthers +editTiddler > fields syncing permalink references jump'></div>
<div class='title' macro='view title'></div>
<div class='subtitle'><span macro='view modifier link'></span>, <span macro='view modified date'></span> (<span macro='message views.wikified.createdPrompt'></span> <span macro='view created date'></span>)</div>
<div class='tagging' macro='tagging'></div>
<div class='tagged' macro='tags'></div>
<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
<!--}}}-->
<!--{{{-->
<div class='toolbar' macro='toolbar +saveTiddler -cancelTiddler deleteTiddler'></div>
<div class='title' macro='view title'></div>
<div class='editor' macro='edit title'></div>
<div macro='annotations'></div>
<div class='editor' macro='edit text'></div>
<div class='editor' macro='edit tags'></div><div class='editorFooter'><span macro='message views.editor.tagPrompt'></span><span macro='tagChooser'></span></div>
<!--}}}-->
To get started with this blank TiddlyWiki, you'll need to modify the following tiddlers:
* SiteTitle & SiteSubtitle: The title and subtitle of the site, as shown above (after saving, they will also appear in the browser title bar)
* MainMenu: The menu (usually on the left)
* DefaultTiddlers: Contains the names of the tiddlers that you want to appear when the TiddlyWiki is opened
You'll also need to enter your username for signing your edits: <<option txtUserName>>
These InterfaceOptions for customising TiddlyWiki are saved in your browser

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

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

----
Also see AdvancedOptions
Background: #ffc
Foreground: #000
PrimaryPale: #8cf
PrimaryLight: #18f
PrimaryMid: #04b
PrimaryDark: #014
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #800
TertiaryPale: #ddd
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
TiddlerBackground: #fe8
[[Welcome to ZhuqiLOG]]
[[The Power of SingleFileWiki]]
@@font-size:140%;''[[Tiddly Help|http://tiddlyspot.com/twhelp/]]''@@

[img[http://images.zhuqipix.multiply.com/logo/1]]
!@@color(red):~ZhuqiLINKS@@
* [[ZhuqiDOX|http://zhuqidox.blogspot.com]]
* [[ZhuqiNUX|http://zhuqinux.blogspot.com]]
* [[ZhuqiPAD|http://zhuqipad.blogspot.com]]
* [[ZhuqiBLOG|http://www.oknation.net/blog/ZhuqiBLOG]]
!@@color(red):~ZhuqiTEXT@@
* [[ZhuqiBOOK's|http://www.esnips.com/web/ZhuqiBOOK]]
* [[ZhuqiDOX's|http://www.esnips.com/web/ZhuqiDOX]]
* [[ZhuqiNUX's|http://www.esnips.com/web/ZhuqiNUX]]
!@@color(red):~ZhuqiPALS@@
* [[ZhuqiPIX|http://zhuqipix.multiply.com]]
<<tabs txtMainTab "List" "Article list" TabList "Tags" "All tags" TabTags "All" "All tiddlers" TabAll "Timeline" "Timeline" TabTimeline "More" "More lists" TabMore>>
an unresonable thinking log of Mr. Z.''
@@color(orange):''~ZhuqiLOG :''@@
/***Part of ~StyleSheet CSS definitions pasted from TW Help***/

/***
!!!Alignment /%==================================================%/
***/
/*{{{*/

.textleft{text-align:left;}
.textright{text-align:right;}
.textcenter{text-align:center;}
.textjustify{text-align:justify;}

.floatleft{ float:left; }
.floatright{ float:right; }

.moveovermainmenu{margin-left:7px;}
.textleftpad5{text-align:left;padding: 0px 5px 0px 5px;}
.textindent25 {text-indent:25px;}
.right{display:block;text-align:right; }
.smallform{ white-space:nowrap; }

.tablecenter  table { border:0 !important;td.vertical-align:top;margin-left: auto; margin-right: auto; text-align:
left; padding:0px;}
.tablecenterpad17 table { td.vertical-align:top;margin-left: auto; margin-right: auto; text-align:
left; padding:17px;}

.imgfloatright{display:block;float:right;padding:1em;}
.imgfloatleft{display:block;float:left;padding:1em;}
.imgfloatcenter{display:block;margin-left: auto;margin-right: auto;padding:1em;}


/***
!!!Formatting /%==================================================%/
***/
/*{{{*/

.borderless, .borderless table, .borderless td, .borderless tr, .borderless th, .borderless tbody
	{ border:0 !important; margin:0 !important; padding:3px !important; td.vertical-align:top !important;margin-left: auto !important; margin-right: auto !important;}

.borderless5px, .borderless5px table, .borderless5px td, .borderless5px tr, .borderless5px th, .borderless5px tbody { border:0 !important; margin:0 !important; padding:5px !important; td.vertical-align:top !important;margin-left: auto !important; margin-right: auto !important;}

.borderlessL, .borderlessL table, .borderlessL td, .borderlessL tr, .borderlessL th, .borderlessL tbody
	{ border:0 !important; margin:0 !important; padding:7px !important; td.vertical-align:top !important;margin-left: 0 !important; margin-right: auto !important;}

.firstletter{
float:left;
width:0.75em;
font-size:400%;
font-family:times,courier;
line-height:80%;
}


/*}}}*/
/***
/*{{{*/
body {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

hr {height:1px;}

a {text-decoration:none;}

dt {font-weight:bold;}

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

.txtOptionInput {width:11em;}

#contentWrapper .chkOptionInput {border:0;}

.externalLink {text-decoration:none; color:#01731A;}

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

.tiddlyLinkExisting {font-weight:normal;}
.tiddlyLinkNonExisting {font-style:italic; color:#FF6300;}

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

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

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

.siteTitle {font-size:2.5em; font-weight:bold;}
.siteSubtitle {font-size:1.5em;}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.whenBackstage {display:none;}
.backstageVisible .whenBackstage {display:block;}
/*}}}*/
[[ZhuqiWikiWorld!!|Welcome to ZhuqiLOG]]
[[TiddlyWiki - Blogs - Wiki]]
[[พลังอำ​นาจแห่ง​ SingleFileWiki|The Power of SingleFileWiki]]
!@@color(blue):''พลังอำ​นาจแห่ง​ ~SingleFileWiki''@@

​คนที่คุ้นเคย​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​ระบบ​​​​​​​​​​​​​​​ใหญ่ๆ​​​​​​​​ ​​​​​​​​อย่าง​​​​​​​​ //~MediaWiki// ​​​​​​​​หรือ​​​​​​​​ Wiki ​​​​​​​​อื่นๆ​​​​​​​​ ​​​​​​​​น่า​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​รู้สึกสงสัย​​​​​​​​​​​​​​​อยู่​​​​​​​​​​​​​​​บ้างว่า​​​​​​​​ ''​​​​​​​​@@font-size:120%;จะ​​​​​​​​​​​​​​​สนใจ​​​​​​​​​​​​​​​กับ​​​​​​​​ //~SingleFileWiki// ​​​​​​​​ไปทำ​​​​​​​​​​​​​​​ไม​​​​​​​​??@@'' ... ​​​​​​​​ซึ่ง​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​คำ​​​​​​​​​​​​​​​ถามที่ผมก็นึกถามตัวเอง​​​​​​​​​​​​​​​อยู่​​​​​​​​​​​​​​​ตั้งแต่ครั้งแรกที่​​​​​​​​​​​​​​​เห็น​​​​​​​​ ~TiddlyWiki ​​​​​​​​ตัวนี้​​​​​​​​​​​​​​​เหมือน​​​​​​​​​​​​​​​กัน​​​​​​​​ ... ;-)

​​​​​​​​โดย​​​​​​​​​​​​​​​เหตุผล​​​​​​​​​​​​​​​แล้ว​​​​​​​​ ​​​​​​​​ด้วย​​​​​​​​​​​​​​​โครงสร้างของการ​​​​​​​​​​​​​​​ใช้​​​​​​​​​​​​​​​ไฟล์​​​​​​​​​​​​​​​เพียงไฟล์​​​​​​​​​​​​​​​เดียว​​​​​​​​ ​​​​​​​​มัน​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​สามารถ​​​​​​​​​​​​​​​เทียบประสิทธิภาพ​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​ระบบ​​​​​​​​​​​​​​​ทั้ง​​​​​​​​​​​​​​​ระบบอย่าง​​​​​​​​ Wiki ​​​​​​​​ทั่วๆ​​​​​​​​ ​​​​​​​​ไป​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​เลย​​​​​​​​ ... ​​​​​​​​แต่คำ​​​​​​​​​​​​​​​ถามที่ควร​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​ต้อง​​​​​​​​​​​​​​​ถามก็คือ​​​​​​​​ ... ''@@font-size:120%;​​​​​​​​จะ​​​​​​​​​​​​​​​เปรียบเทียบ​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ทำ​​​​​​​​​​​​​​​ไม​​​​​​​​?@@'' ... ​​​​​​​​เพราะ​​​​​​​​​​​​​​​สิ่งที่ควร​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​สนใจ​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​อยู่​​​​​​​​​​​​​​​ที่ว่าตัวไหนเก่งกว่าตัวไหน​​​​​​​​ ... ​​​​​​​​แต่มันควร​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​อยู่​​​​​​​​​​​​​​​ที่​​​​​​​​ ... ''@@font-size:120%;​​​​​​​​มันทำ​​​​​​​​​​​​​​​ประ​​​​​​​​​​​​​​​โยชน์อะ​​​​​​​​​​​​​​​ไร​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​บ้าง​​​​​​​​?@@'' ​​​​​​​​ต่างหาก​​​​​​​​ !!

​​​​​​​​อย่างแรกเลยก็คือ​​​​​​​​ ~Wiki-Style ​​​​​​​​มีการออกแบบ​​​​​​​​ //markup language// ​​​​​​​​หรือ​​​​​​​​ //syntax// ​​​​​​​​ที่ค่อนข้างสะดวกสำ​​​​​​​​​​​​​​​หรับการ​​​​​​​​​​​​​​​ใช้​​​​​​​​​​​​​​​บันทึกบท​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ต่างๆ​​​​​​​​ ​​​​​​​​เพื่อสร้าง​​​​​​​​ web-contents //(ค่อนข้างสะดวก​​​​​​​​ ​​​​​​​​แต่​​​​​​​​​​​​​​​ยัง​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​ง่ายซะที​​​​​​​​​​​​​​​เดียว)// ​​​​​​​​อัน​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​สื่อที่​​​​​​​​​​​​​​​สามารถ​​​​​​​​​​​​​​​เผยแพร่​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​รู้​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​อย่างแพร่หลาย​​​​​​​​ ... ​​​​​​​​อัน​​​​​​​​​​​​​​​เนื่อง​​​​​​​​​​​​​​​จาก​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ที่มัน​​​​​​​​''​​​​​​​​ไม่​​​​​​​​​​​​​​​จำ​​​​​​​​​​​​​​​กัด​​​​​​​​ platform ​​​​​​​​ของ​​​​​​​​ OS ​​​​​​​​ประจำ​​​​​​​​​​​​​​​เครื่องของแต่ละคน​​​​​​​​''​​​​​​​​นั่นเอง​​​​​​​​ ... ​​​​​​​​เพราะ​​​​​​​​​​​​​​​ทุกๆ​​​​​​​​ ​​​​​​​​อย่าง​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​ทำ​​​​​​​​​​​​​​​งานผ่าน​​​​​​​​ web browser ​​​​​​​​ซึ่ง​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​ตัวเชื่อมโยง​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​กลไกการทำ​​​​​​​​​​​​​​​งานของ​​​​​​​​ OS ​​​​​​​​ต่างๆ​​​​​​​​ ​​​​​​​​อีกชั้นหนึ่ง​​​​​​​​ ... ''​​​​​​​​และ​​​​​​​​​​​​​​​ทำ​​​​​​​​​​​​​​​ให้​​​​​​​​ contents ​​​​​​​​หรือ​​​​​​​​​​​​​​​เนื้อหา​​​​​​​​​​​​​​​ทั้ง​​​​​​​​​​​​​​​หมด​​​​​​​​ ​​​​​​​​กลาย​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​เอกสารประ​​​​​​​​​​​​​​​เภท​​​​​​​​ platform independence ​​​​​​​​ทันที​​​​​​​​ !!''

​​​​​​​​หากเรา​​​​​​​​​​​​​​​เปรียบเทียบ​​​​​​​​ ~TiddlyWiki ​​​​​​​​กับ​​​​​​​​​​​​​​​ระบบ​​​​​​​​ Wiki ​​​​​​​​ขนาด​​​​​​​​​​​​​​​ใหญ่​​​​​​​​​​​​​​​อื่นๆ​​​​​​​​ ... ​​​​​​​​แน่นอนที่มัน​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​เทียบชั้น​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​เลย​​​​​​​​​​​​​​​ด้วย​​​​​​​​​​​​​​​ตัวของมันเอง​​​​​​​​ ... ​​​​​​​​แต่​​​​​​​​​​​​​​​ถ้า​​​​​​​​​​​​​​​หากเรา​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​เปรียบเทียบ​​​​​​​​ ~TiddlyWiki ​​​​​​​​กับ​​​​​​​​ word processor ​​​​​​​​ที่​​​​​​​​//​​​​​​​​มนุษย์สำ​​​​​​​​​​​​​​​นักงาน​​​​​​​​//​​​​​​​​ทั่ว​​​​​​​​​​​​​​​ไปคุ้นเคย​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ล่ะ​​​​​​​​?! ... ​​​​​​​​ผมเชื่อว่า​​​​​​​​ ​​​​​​​​นี่คือ​​​​​​​​''//​​​​​​​​มุมมอง​​​​​​​​//''​​​​​​​​ที่ย่อม​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​สร้าง​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​แตกต่างทาง​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​รู้สึกของทุกคนอย่างสิ้นเชิงเลยที​​​​​​​​​​​​​​​เดียว​​​​​​​​ ...

"ชุดซอต์​​​​​​​​​​​​​​​แวร์สำ​​​​​​​​​​​​​​​นักงาน" ​​​​​​​​หรือ​​​​​​​​ Office Suites ​​​​​​​​ที่หลายๆ​​​​​​​​ ​​​​​​​​คนรู้จัก​​​​​​​​ ​​​​​​​​และ​​​​​​​​​​​​​​​ปวดหัว​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​มัน​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ไม่​​​​​​​​ compatible ​​​​​​​​ของการส่งผ่านไฟล์ข้าม​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ไปๆ​​​​​​​​ ​​​​​​​​มาๆ​​​​​​​​ ​​​​​​​​ระหว่าง​​​​​​​​ platform ​​​​​​​​ของ​​​​​​​​ OS ​​​​​​​​ต่างๆ​​​​​​​​ ​​​​​​​​นั้น​​​​​​​​ ​​​​​​​​น่า​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​เป็น​​​​​​​​''​​​​​​​​เรื่องปกติ​​​​​​​​''​​​​​​​​ที่ทุกคนยอมรับมันว่า​​​​​​​​ ​​​​​​​​เป็น​​​​​​​​//​​​​​​​​ส่วน​​​​​​​​​​​​​​​หนึ่งของธรรมชาติที่​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​จำ​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​ต้อง​​​​​​​​​​​​​​​เยียวยา​​​​​​​​​​​​​​​ใดๆ​​​​​​​​// ​​​​​​​​กับ​​​​​​​​​​​​​​​ยอมทนทุกข์ทรมาน​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​เอา​​​​​​​​​​​​​​​ไหนของการบริหารจัดการ​​​​​​​​​​​​​​​ให้​​​​​​​​​​​​​​​ซอฟต์​​​​​​​​​​​​​​​แวร์ทุกๆ​​​​​​​​ ​​​​​​​​ตัวยอมหันหน้า​​​​​​​​​​​​​​​เข้า​​​​​​​​​​​​​​​หา​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​อย่างจริงจัง​​​​​​​​ ​​​​​​​​เพื่อประ​​​​​​​​​​​​​​​โยชน์​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​การสื่อสารระหว่าง​​​​​​​​​​​​​​​ผู้​​​​​​​​​​​​​​​บริ​​​​​​​​​​​​​​​โภค​​​​​​​​​​​​​​​โดย​​​​​​​​​​​​​​​ตรง​​​​​​​​ ... ​​​​​​​​นั่นคือสิ่งที่บ่อนทำ​​​​​​​​​​​​​​​ลายประสิทธิภาพของเวลาทำ​​​​​​​​​​​​​​​งานลงไปอย่างมหาศาล​​​​​​​​ ​​​​​​​​เพราะ​​​​​​​​​​​​​​​หลายคน​​​​​​​​​​​​​​​ยัง​​​​​​​​​​​​​​​ต้อง​​​​​​​​​​​​​​​เสียเวลา​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​การแปลงไฟล์ข้าม​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ข้าม​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​มา​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​กิจวัตร​​​​​​​​ ​​​​​​​​หรือ​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​อย่าง​​​​​​​​​​​​​​​นั้น​​​​​​​​ ​​​​​​​​ก็​​​​​​​​​​​​​​​ต้อง​​​​​​​​​​​​​​​เลือกส่งไฟล์​​​​​​​​​​​​​​​ให้​​​​​​​​​​​​​​​แก่​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​รูปแบบที่​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​สะดวกสำ​​​​​​​​​​​​​​​หรับการปรับปรุงแก้​​​​​​​​​​​​​​​ไข​​​​​​​​​​​​​​​ใดๆ​​​​​​​​ ​​​​​​​​และ​​​​​​​​​​​​​​​ทำ​​​​​​​​​​​​​​​ให้​​​​​​​​​​​​​​​ขั้นตอนของการสื่อสาร​​​​​​​​ ​​​​​​​​ต้อง​​​​​​​​​​​​​​​สะดุด​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​ช่วงๆ​​​​​​​​ ​​​​​​​​ตลอดระยะ​​​​​​​​​​​​​​​เวลาของการทำ​​​​​​​​​​​​​​​งานร่วม​​​​​​​​​​​​​​​กัน​​​​​​​​ ...

​​​​​​​​แต่ปัญหา​​​​​​​​​​​​​​​เหล่านี้น่า​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​หายสาบสูญไป​​​​​​​​​​​​​​​จาก​​​​​​​​​​​​​​​โลกของ​​​​​​​​//​​​​​​​​มนุษย์สำ​​​​​​​​​​​​​​​นักงาน​​​​​​​​//​​​​​​​​มั้ย​​​​​​​​ ​​​​​​​​ถ้า​​​​​​​​​​​​​​​เรา​​​​​​​​​​​​​​​เปลี่ยนมาส่งเอกสารประ​​​​​​​​​​​​​​​เภทบท​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ด้วย​​​​​​​​ ~SingleFileWiki ??!! ... ​​​​​​​​ซึ่ง​​​​​​​​​​​​​​​นี่คือ​​​​​​​​''​​​​​​​​พลังอำ​​​​​​​​​​​​​​​นาจ​​​​​​​​''​​​​​​​​ที่น่าสนใจที่สุดของ​​​​​​​​ ~TiddlyWiki ​​​​​​​​ที่มองๆ​​​​​​​​ ​​​​​​​​ดูผ่านๆ​​​​​​​​ ​​​​​​​​ใน​​​​​​​​​​​​​​​เบื้องต้น​​​​​​​​​​​​​​​แล้ว​​​​​​​​ ​​​​​​​​ไม่​​​​​​​​​​​​​​​น่า​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​ใช้​​​​​​​​​​​​​​​ประ​​​​​​​​​​​​​​​โยชน์อะ​​​​​​​​​​​​​​​ไร​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​เลย​​​​​​​​ ... ''​​​​​​​​การเขียนตำ​​​​​​​​​​​​​​​รับตำ​​​​​​​​​​​​​​​รา​​​​​​​​​​​​​​​ด้วย​​​​​​​​ word processor ​​​​​​​​แล้ว​​​​​​​​​​​​​​​เก็บเอา​​​​​​​​​​​​​​​ไว้​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​ไฟล์ๆ​​​​​​​​ ​​​​​​​​เดียว​​​​​​​​ ​​​​​​​​แทบ​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​มีอะ​​​​​​​​​​​​​​​ไรที่​​​​​​​​​​​​​​​แตกต่าง​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​การเขียนเอกสารชุดเดียว​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ด้วย​​​​​​​​ web browser ​​​​​​​​แล้ว​​​​​​​​​​​​​​​เก็บ​​​​​​​​​​​​​​​ไว้​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​ไฟล์ประ​​​​​​​​​​​​​​​เภท​​​​​​​​ ~SingleFileWiki ​​​​​​​​เลย​​​​​​​​'' ... ​​​​​​​​เพราะ​​​​​​​​​​​​​​​มันก็คือไฟล์​​​​​​​​​​​​​​​เดี่ยวๆ​​​​​​​​ ​​​​​​​​ที่​​​​​​​​​​​​​​​ใช้​​​​​​​​​​​​​​​เพื่อบรรจุ​​​​​​​​​​​​​​​เนื้อ​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ทั้ง​​​​​​​​​​​​​​​หมดที่​​​​​​​​​​​​​​​เราา​​​​​​​​​​​​​​​ต้อง​​​​​​​​​​​​​​​การสื่อสารเหมือน​​​​​​​​​​​​​​​กัน​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​ทาง​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​หมาย​​​​​​​​ ... ​​​​​​​​แต่ว่า​​​​​​​​ ...

​​​​​​​​การสร้างไฟล์​​​​​​​​​​​​​​​ให้​​​​​​​​​​​​​​​เป็น​​​​​​​​ ~SingleFileWiki ​​​​​​​​ย่อม​​​​​​​​//​​​​​​​​พ้นบ่วงกรรมของการพึ่งพิง​​​​​​​​//​​​​​​​​ซอฟต์​​​​​​​​​​​​​​​แวร์ที่​​​​​​​​​​​​​​​เฉพาะ​​​​​​​​​​​​​​​เจาะจง​​​​​​​​ ​​​​​​​​ทั้ง​​​​​​​​​​​​​​​ยัง​​​​​​​​​​​​​​​รอดพ้น​​​​​​​​​​​​​​​จาก​​​​​​​​​​​​​​​การยึดติด​​​​​​​​​​​​​​​อยู่​​​​​​​​​​​​​​​กับ​​​​​​​​ OS ​​​​​​​​ค่าย​​​​​​​​​​​​​​​ใด​​​​​​​​​​​​​​​ค่ายหนึ่งอย่างฝังกระ​​​​​​​​​​​​​​​โหลก​​​​​​​​​​​​​​​ด้วย​​​​​​​​ ​​​​​​​​ปัญหา​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​ด้านขั้นตอนของการสื่อสารแทบ​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​สูญสลายไปจนหมดสิ้น​​​​​​​​ ​​​​​​​​และ​​​​​​​​​​​​​​​ปล่อย​​​​​​​​​​​​​​​ให้​​​​​​​​ word processor ​​​​​​​​ทุกๆ​​​​​​​​ ​​​​​​​​ตัว​​​​​​​​ ​​​​​​​​อยู่​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​ที่​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​ทางที่​​​​​​​​​​​​​​​เหมาะสมสำ​​​​​​​​​​​​​​​หรับการ​​​​​​​​​​​​​​​ใช้​​​​​​​​​​​​​​​งานของพวกมัน​​​​​​​​ ... ​​​​​​​​เพราะ​​​​​​​​​​​​​​​มัน​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​ใช่​​​​​​​​//​​​​​​​​จ้าวโลก​​​​​​​​//​​​​​​​​ของการสื่อสาร​​​​​​​​​​​​​​​ด้วย​​​​​​​​​​​​​​​ไฟล์อีกต่อไป​​​​​​​​​​​​​​​แล้ว​​​​​​​​

​​​​​​​​นอก​​​​​​​​​​​​​​​จาก​​​​​​​​​​​​​​​นั้น​​​​​​​​​​​​​​​แล้ว​​​​​​​​ ​​​​​​​​การเขียนบท​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ขนาดยาวๆ​​​​​​​​ ​​​​​​​​ที่มีการแบ่ง​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​หลายๆ​​​​​​​​ ​​​​​​​​ส่วน​​​​​​​​ ​​​​​​​​ก็​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​สามารถ​​​​​​​​​​​​​​​ประ​​​​​​​​​​​​​​​โยชน์​​​​​​​​​​​​​​​จาก​​​​​​​​ //markup language// ​​​​​​​​ของ​​​​​​​​ Wiki ​​​​​​​​ได้​​​​​​​​​​​​​​​อย่างเต็มที่​​​​​​​​ ​​​​​​​​โดย​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​จำ​​​​​​​​​​​​​​​เป็น​​​​​​​​​​​​​​​ต้อง​​​​​​​​​​​​​​​ช่ำ​​​​​​​​​​​​​​​ชอง​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​ภาษา​​​​​​​​ HTML ​​​​​​​​ของ​​​​​​​​ web ​​​​​​​​ใน​​​​​​​​​​​​​​​ยุคแรกๆ​​​​​​​​ ​​​​​​​​อีกต่อไป​​​​​​​​ ​​​​​​​​เพราะ​​​​​​​​​​​​​​​ผู้​​​​​​​​​​​​​​​อ่าน​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​สามารถ​​​​​​​​​​​​​​​เลือกกระ​​​​​​​​​​​​​​​โดดข้ามไปข้ามมาระหว่างแต่ละ​​​​​​​​​​​​​​​ส่วน​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​อย่างคล่องตัวที่สุด​​​​​​​​ ​​​​​​​​โดย​​​​​​​​​​​​​​​ผู้​​​​​​​​​​​​​​​เขียนบท​​​​​​​​​​​​​​​ความ​​​​​​​​ ​​​​​​​​เพียงแต่ตั้งสารบัญหัวเรื่อง​​​​​​​​​​​​​​​ทั้ง​​​​​​​​​​​​​​​หมด​​​​​​​​​​​​​​​ไว้​​​​​​​​​​​​​​​ให้​​​​​​​​​​​​​​​เท่า​​​​​​​​​​​​​​​นั้น​​​​​​​​​​​​​​​ก็พอ​​​​​​​​​​​​​​​แล้ว​​​​​​​​

​​​​​​​​และ​​​​​​​​​​​​​​​เมื่อเรานำ​​​​​​​​ ~SingleFileWiki ​​​​​​​​หลายๆ​​​​​​​​ ​​​​​​​​ไฟล์มารวม​​​​​​​​​​​​​​​ไว้​​​​​​​​​​​​​​​ด้วย​​​​​​​​​​​​​​​กัน​​​​​​​​ ... ​​​​​​​​มันก็​​​​​​​​​​​​​​​ยัง​​​​​​​​​​​​​​​สามารถ​​​​​​​​​​​​​​​กระ​​​​​​​​​​​​​​​โดดข้ามไป​​​​​​​​​​​​​​​ยัง​​​​​​​​​​​​​​​ไฟล์​​​​​​​​​​​​​​​อื่นๆ​​​​​​​​ ​​​​​​​​ที่มี​​​​​​​​​​​​​​​อยู่​​​​​​​​ ​​​​​​​​ทั้ง​​​​​​​​​​​​​​​ยัง​​​​​​​​​​​​​​​สามารถ​​​​​​​​​​​​​​​ระบุตำ​​​​​​​​​​​​​​​แหน่งของ​​​​​​​​​​​​​​​ส่วน​​​​​​​​​​​​​​​ที่​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​กระ​​​​​​​​​​​​​​​โดดไป​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​อีก​​​​​​​​​​​​​​​ด้วย​​​​​​​​ ​​​​​​​​ซึ่ง​​​​​​​​​​​​​​​ผมเชื่อว่า​​​​​​​​ ​​​​​​​​ผู้​​​​​​​​​​​​​​​ที่ออกแบบ​​​​​​​​ Tiddlywiki ​​​​​​​​ขึ้นมาน่า​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​ตระหนัก​​​​​​​​​​​​​​​ถึง​​​​​​​​''​​​​​​​​พลังอำ​​​​​​​​​​​​​​​นาจ​​​​​​​​''​​​​​​​​ของ​​​​​​​​ features ​​​​​​​​นี้มาตั้งแต่​​​​​​​​​​​​​​​แรก​​​​​​​​ ​​​​​​​​จึง​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​สร้าง​​​​​​​​ ~SingleFileWiki Community ​​​​​​​​อย่าง​​​​​​​​ [[tiddlyspot|http://tiddlyspot.com]] ​​​​​​​​ขึ้นมารองรับ​​​​​​​​​​​​​​​ไว้​​​​​​​​ ...

​​​​​​​​โดย​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​เห็น​​​​​​​​​​​​​​​ส่วน​​​​​​​​​​​​​​​ตัว​​​​​​​​ ​​​​​​​​ณ​​​​​​​​ ​​​​​​​​เวลานี้​​​​​​​​ ... ​​​​​​​​ผมเชื่อว่า​​​​​​​​ ~SingleFileWiki ​​​​​​​​น่า​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​กลาย​​​​​​​​​​​​​​​เป็น​​​​​​​​//​​​​​​​​มาตรฐาน​​​​​​​​​​​​​​​ใหม่​​​​​​​​//​​​​​​​​ของการทำ​​​​​​​​​​​​​​​งาน​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​บท​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​ต่างๆ​​​​​​​​ ​​​​​​​​ที่มีพลังอำ​​​​​​​​​​​​​​​นาจเหนือกว่า​​​​​​​​ word processor ​​​​​​​​ที่​​​​​​​​​​​​​​​ใช้​​​​​​​​​​​​​​​งาน​​​​​​​​​​​​​​​อยู่​​​​​​​​​​​​​​​กับ​​​​​​​​​​​​​​​เครื่องคอมพิวเตอร์​​​​​​​​​​​​​​​ส่วน​​​​​​​​​​​​​​​บุคคล​​​​​​​​​​​​​​​ทั่วๆ​​​​​​​​ ​​​​​​​​ไป​​​​​​​​ ​​​​​​​​หรือ​​​​​​​​​​​​​​​แม้​​​​​​​​​​​​​​​แต่น่า​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​มีพลังอำ​​​​​​​​​​​​​​​นาจที่​​​​​​​​​​​​​​​เหนือกว่า​​​​​​​​ Blogs ​​​​​​​​ซึ่ง​​​​​​​​​​​​​​​มีศักยภาพที่ด้อยกว่า​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​การเชื่อมโยงบท​​​​​​​​​​​​​​​ความ​​​​​​​​​​​​​​​จาก​​​​​​​​​​​​​​​หลายๆ​​​​​​​​  Blogs ​​​​​​​​ให้​​​​​​​​​​​​​​​สามารถ​​​​​​​​​​​​​​​เข้า​​​​​​​​​​​​​​​ถึง​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​ง่ายๆ​​​​​​​​ ​​​​​​​​อย่างที่​​​​​​​​ ~SingleFileWiki ​​​​​​​​ทำ​​​​​​​​​​​​​​​อยู่​​​​​​​​​​​​​​​ใน​​​​​​​​​​​​​​​เวลานี้​​​​​​​​ ... ''​​​​​​​​@@font-size:120%;นี่คือ​​​​​​​​ Community Jigsaw ​​​​​​​​ที่​​​​​​​​​​​​​​​ไม่​​​​​​​​​​​​​​​อาจ​​​​​​​​​​​​​​​จะ​​​​​​​​​​​​​​​มองข้ามไป​​​​​​​​​​​​​​​ได้​​​​​​​​​​​​​​​เลย​​​​​​​​ ... ​​​​​​​​จริงๆ​​​​​​​​ !!@@''

~TiddlyWiki ถูกออกแบบมาให้ทำงานในลักษณะของ //Personal Wiki// เพื่อให้ผู้ใช้งานสามารถบันทึกบทความต่างๆ ได้ภายในไฟล์เพียงไฟล์เดียว และไม่จำเป็นต้องมีการติดตั้งระบบ servers ให้ยุ่งยาก ซึ่งตามลักษณะของการทำงานดังที่กำหนดไว้นี้ ทำให้ ~TiddlyWiki ไม่เหมาะกับการทำเป็น //~WikiWikiWeb// ขนาดใหญ่ที่มีความสลับซับซ้อนเหมือนดังเช่น //~WikiWikiWeb// อื่นๆ และค่อนข้างจะมีข้อจำกัดในเรื่องของการทำ collaboration ระหว่าง //"ผู้เขียนบทความ"// และ //"ผู้อ่านบทความ"// เนื่องจากไม่มี module ใดๆ ที่สามารถกำหนดให้ //"ผู้อ่าน"// สามารถมี''ปฏิสัมพันธ์''ใดๆ กับบทความหนึ่งๆ ได้เลย ... จึงต้องถือว่าเป็น //Personal Wiki// เต็มรูปแบบจริงๆ

''อย่างไรก็ตาม //Personal Wiki// ดังที่ผมเรียกนี้ ก็ไม่ได้มีข้อที่ด้อยไปกว่า //Weblogs// ทั่วๆ ไป ซึ่งโดยส่วนมากก็จะมีลักษณะเป็น personal contents อยู่แล้ว และเป็น //"การสื่อสารทางเดียว"// เหมือนกัน'' ... ดังนั้น เราจึงต้องย้อนกลับมาทบทวนความแตกต่างระหว่าง //~WikiWikiWeb// กับ //Weblogs// ว่า ยังมีส่วนใดที่ระบบไหนดีกว่ากัน? หรือระบบทั้งสองมีความเหมาะสมกับงานในลักษณะใดที่แตกต่างกันบ้าง?

จุดที่ดูเหมือนจะเป็นข้อเปรียบเทียบที่ชัดเจนที่สุดระหว่าง //~WikiWikiWeb// กับ //~WeBlogs// ก็คือ
* ''~WikiWikiWeb'' หรือ ''Wiki'' จะจัดการกับ contents ทั้งหมดในลักษณะของ articles และสามารถเชื่อมโยงระหว่าง articles ทั้งหมดได้อย่างคล่องตัวกว่า ทำให้สามารถเชื่อมโยงบทความที่มีการอ้างอิงถึงกันแบบ cross referencing ได้โดยง่าย รวมทั้งยังสามารถสร้าง //"จุดเชื่อมโยง"// ภายในบทความเดียวกันที่มีขนาดยาวๆ ได้สะดวกกว่าด้วย
* ''Weblogs'' หรือ ''Blogs'' จะจัดการกับ contents ทั้งหมดในลักษณะของ chronological orders คือใช้วิธีเรียงลำดับย้อนเวลาของการสร้าง contents หนึ่งๆ เป็นหลัก ทำให้ความต่อเนื่อง และการเชื่อมโยงระหว่าง contents ทั้งหลาย มีความ //"ไม่สะดวก"// เท่ากับในระบบของ //Wiki// และการขยายบทความใดบทความหนึ่งใน //Blogs// ให้มีความยาวมากๆ ก็จะสร้างภาระที่ยุ่งยากให้กับ //"ผู้อ่าน"// ด้วย เนื่องจากการสร้าง //"จุดเชื่อมโยง"// ภายในบทความชิ้นเดียวกันนั้น ยังไม่สามารถทำได้ในโลกของ //Blogs//

อย่างไรก็ตาม การจัดหมวดหมู่แบบ articles หรือแบบ chronological นั้น ไม่น่าจะเป็นส่วนที่แตกต่างกันอย่างแท้จริงของระบบทั้งสอง เนื่องจากระบบ CMS ที่นำมาจัดการกับ contents ต่างๆ นั้น สามารถที่จะกำหนดให้หน้าเว็บเลือกแสดงเป็นรูปแบบใดรูปแบบหนึ่งได้โดยไม่ยากเย็นอยู่แล้ว ... ''ธรรมชาติที่แตกต่างกันจริงๆ ของ //Wiki// และ //Blogs// จึงควรจะอยู่ที่ว่า ทั้งสองระบบได้ถูกกำหนด concept มาให้ handle บทความที่มีลักษณะและขนาดที่ไม่เหมือนกันมาตั้งแต่ต้นนั่นเอง''

//Blogs// ถูกพัฒนาขึ้นมาเพื่อใช้ handle บทความสั้นๆ ในลักษณะของ journal เท่านั้นเอง ซึ่งโดยมากก็มักจะเป็นบทความที่ถูกตัดเป็นท่อนๆ ไม่มีความต่อเนื่องกัน ... และ //"ไม่จำเป็น"// ต้องต่อเนื่องกันด้วย

ในขณะที่ //Wiki// ถูกพัฒนาขึ้นมาเพื่อการเขียนบทความยาวๆ ซึ่งสามารถแยกออกเป็นหลายๆ ส่วน หรือหลายๆ ไฟล์ แล้วนำมาเชื่อมโยงถึงกันด้วย //"ไวยากรณ์"// หรือ syntax พิเศษที่ออกแบบเอาไว้ ... และโดย concept ของการพัฒนาระบบดังกล่าวนี้เอง จึงทำให้ //Wiki// เหมาะกับการเขียนบทความเชิงวิชาการ หรือบันทึกงานวิจัยต่างๆ ที่จำเป็นต้องมีการทำ cross referencing ที่สลับซับซ้อน ซึ่งแม้แต่ word processor ที่เคยพัฒนากันมาทั้งหมด ก็ยังจัดการกับเอกสารประเภทนี้ลำบากมาก

ดังนั้น ''หากจะมองในแง่ของความยืดหยุ่นต่อการใช้งานแล้ว //Wiki// จะเป็นระบบที่มีความพร้อมในหลายๆ ด้านมากกว่า //Blogs//'' ... แต่ก็เพราะความสามารถที่สูงกว่านี้เอง จึงทำให้ //Wiki// มี //"ชุดคำสั่ง"// หรือรูปแบบ //"ไวยากรณ์"// ในการเขียนที่ซับซ้อนกว่า //Blogs// พอสมควร ''ซึ่งหากสามารถแก้ไขปรับปรุงในส่วนของ UI (User Interface) ให้เป็นที่เข้าใจง่ายโดยผู้ใช้งานส่วนใหญ่แล้ว การสร้างเอกสารแบบ //Wiki// น่าจะเป็นทางเลือกที่เหมาะสมที่สุดสำหรับการสร้าง contents ในระบบ CMS ในระยะหลายปีนี้''

/***
Contains the stuff you need to use Tiddlyspot
Note you must also have UploadPlugin installed
***/
//{{{

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

// 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)

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

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

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

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

'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/]], [[announcements|http://announce.tiddlyspot.com/]], [[blog|http://tiddlyspot.com/blog/]], email [[support|mailto:support@tiddlyspot.com]] & [[feedback|mailto:feedback@tiddlyspot.com]], [[donate|http://tiddlyspot.com/?page=donate]]|"
].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"),

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

});
//}}}
| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |
| 02/10/2007 15:59:18 | Zhuq! | [[zhuqilog.html|file:///home/viruch/ZhuqiWEB/zhuqilog.html]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . | ok |
| 02/10/2007 16:05:39 | Zhuq! | [[zhuqilog.html|file:///home/viruch/ZhuqiWEB/zhuqilog.html]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . | ok |
| 02/10/2007 16:10:59 | Zhuq! | [[zhuqilog.html|file:///home/viruch/ZhuqiWEB/zhuqilog.html]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . |
| 03/10/2007 00:05:50 | Zhuq! | [[/|http://zhuqilog.tiddlyspot.com/]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . | ok |
| 03/10/2007 00:07:47 | Zhuq! | [[/|http://zhuqilog.tiddlyspot.com/]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . |
| 05/10/2007 22:13:13 | Zhuq! | [[zhuqilog.html|file:///home/viruch/ZhuqiWEB/zhuqilog.html]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . |
| 06/10/2007 00:20:42 | Zhuq! | [[/|http://zhuqilog.tiddlyspot.com/]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . |
| 07/10/2007 07:35:43 | Zhuq! | [[zhuqilog.html|file:///home/viruch/ZhuqiWEB/zhuqilog.html]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . |
| 07/10/2007 07:46:29 | Zhuq! | [[/|http://zhuqilog.tiddlyspot.com/]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . |
| 07/10/2007 16:06:03 | Zhuq! | [[zhuqilog.html|file:///home/viruch/ZhuqiWEB/zhuqilog.html]] | [[store.cgi|http://zhuqilog.tiddlyspot.com/store.cgi]] | . | [[index.html | http://zhuqilog.tiddlyspot.com/index.html]] | . |
/***
|''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"
	});
*/
//}}}

/***
|''Name:''|UploadPlugin|
|''Description:''|Save to web a TiddlyWiki|
|''Version:''|4.1.0|
|''Date:''|May 5, 2007|
|''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 (#3125)|
|''Requires:''|PasswordOptionPlugin|
***/
//{{{
version.extensions.UploadPlugin = {
	major: 4, minor: 1, revision: 0,
	date: new Date("May 5, 2007"),
	source: 'http://tiddlywiki.bidix.info/#UploadPlugin',
	author: 'BidiX (BidiX (at) bidix (dot) info',
	coreVersion: '2.2.0 (#3125)'
};

//
// 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
		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}
				
			]);
	},
	refreshOptions: function(listWrapper) {
		var uploadOpts = [
			"txtUploadUserName",
			"pasUploadPassword",
			"txtUploadStoreUrl",
			"txtUploadDir",
			"txtUploadFilename",
			"txtUploadBackupDir",
			"chkUploadLog",
			"txtUploadLogMaxLine",
			]
		var opts = [];
		for(i=0; i<uploadOpts.length; i++) {
			var opt = {};
			opts.push()
			opt.option = "";
			n = uploadOpts[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 = 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,null,null,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 = Array(uploadParams[0],rssPath,uploadParams[2],'',uploadParams[4],uploadParams[5]);
		bidix.upload.httpUpload(rssUploadParams,convertUnicodeToUTF8(generateRss()),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 == httpStatus.NotFound)
			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; 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');


/* don't want this for tiddlyspot sites

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

*/


//}}}


<br>@@font-size:120%;''สวัสดีครับทุกๆ คน,''@@

นี่คือการทดสอบ //personal wiki pages// เพื่อเตรียมความพร้อมบางอย่างในการออกแบบระบบเว็บไซต์ที่ยังคิดค้างๆ เอาไว้ในสมองก้อนเล็กๆ ของผม หลังจากที่ได้ทดสอบโปรแกรมที่ชื่อว่า [[Zim : Desktop Wiki|http://pardus-larus.student.utwente.nl/%7Epardus/projects/zim/index.shtml]] บน [[Linux|http://www.kernel.org/]] ได้ระยะหนึ่ง และพบเห็นศักยภาพบางอย่างของการทำงานแบบที่หลายๆ คนคุ้นหูคุ้นตาว่า ~Wiki-Style ซึ่งน่าจะทำให้ประโยชน์ได้หลายๆ อย่าง โดยเฉพาะในการเผยแพร่บทความ และความรู้ต่างๆ

ผมพบ tiddlyspot.com โดยบังเอิญจากการพยายามค้นหา ~Wiki-Style Text Editor เพื่อมาใช้งานบนเครื่อง OSX ของผมเอง ประกอบกับกำลังนึกมันมือที่อยากจะหาแหล่งพัฒนาทักษะในการเขียน syntax ต่างๆ ของ ~Wiki-Style ด้วย จึงตัดสินใจ host เจ้าเว็บชื่อประหลาดนี่ขึ้นมาเป็น "สถานีทดลอง" แรกของตัวเอง ;-)

@@font-size:120%;''Mr. Z.''@@