tag, and line feeds are not escaped.
+
+And, weirdly, there is no HTML encoding of the body.
+
+```
+
+これらの`*.tiddler`ファイルは、HTML エンコードされたTiddlyWiki HTMLファイル内のTiddlerとまったく同じではありません。
+
+Older `*.tiddler` files more closely matched the store format used by TiddlyWiki at the time:
+古い`*.tiddler`ファイルは、当時TiddlyWikiで使用されていたストア形式に似ています:
+
+```
+
This is an old-school .tiddler file, without an embedded <pre> tag.\nNote how the body is "HTML encoded" and new lines are escaped to \\n
+```
+
+//`application/x-tiddler-html-div` ContentTypeはこれらのファイルの内部で使用されます//
+
+!! ~TiddlyWebスタイルのJSONファイル
+
+これらのファイルは、`name:value`プロパティのハッシュマップの単純な配列です。すべてのフィールド値は文字列として指定する必要があります。
+
+例:
+
+```
+[
+ {
+ "title": "First Tiddler",
+ "text": "Text of first tiddler",
+ "tags": "one two [[t h r e e]]"
+ },{
+ "title": "Second Tiddler",
+ "text": "Text of second tiddler",
+ "modified": "20150216171751154"
+ }
+]
+```
+
+`application/json` ContentTypeはこれらのファイルに対して内部で使用されます。
+
+Tiddler構造に準拠していないJSONファイルは、代わりにJSONデータを含む単一のTiddlerとしてインポートされることに注意してください。
+
+!! TiddlyWiki HTMLファイル用の新しいJSONベースの形式
+
+TiddlyWiki HTMLファイルの新しい形式では、スクリプトタグ内にJSON形式のTiddlerが埋め込まれます:
+
+```json
+
+```
+
+!! TiddlyWiki HTMLファイル用の古いDIVベースの形式
+
+TiddlyWikiクラシックおよびバージョンv5.2.0より前のTiddlyWiki 5では、Tiddlerは`
''2.'' Linuxシステムでは、変数を定義するだけでなく//''export''//する必要もあります。
+"""/>
+
+追加のパスはそれぞれ、~TiddlyWiki5 GitHubリポジトリの同等のディレクトリのように、構造化されたフォルダを指す必要があります: プラグイン、テーマ、言語のディレクトリには`publisher/pluginname/`が含まれ、エディションのディレクトリには`editionname/`が含まれます
+
+例:
+
+```
+export TIDDLYWIKI_PLUGIN_PATH=~/MyPluginStore
+tiddlywiki mywiki --build index
+```
diff --git a/editions/ja-JP/tiddlers/nodejs/Installing TiddlyWiki Prerelease on Node.js.tid b/editions/ja-JP/tiddlers/nodejs/Installing TiddlyWiki Prerelease on Node.js.tid
new file mode 100644
index 000000000..5ba15078a
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Installing TiddlyWiki Prerelease on Node.js.tid
@@ -0,0 +1,16 @@
+created: 20150926162849519
+modified: 20241228110350676
+original-modified: 20191022095509822
+tags: [[TiddlyWiki on Node.js]]
+title: Installing TiddlyWiki Prerelease on Node.js
+ja-title: Node.jsにTiddlyWikiプレリリースをインストールする
+type: text/vnd.tiddlywiki
+
+# https://github.com/TiddlyWiki/TiddlyWiki5 からTiddlyWiki5 GitHubリポジトリのローカルコピーをクローンします
+# コマンドラインターミナルを開き、現在の作業ディレクトリをTiddlyWiki5リポジトリのルートに変更します
+# `npm link` (Windows) または `sudo npm link` (Mac/Linux) と入力して、[[npm]]にこのリポジトリのコピーをグローバルにインストールされたものとして使用するように指示します
+# ルート内で、次のようにして~TiddlyWikiを起動できます: ``tiddlywiki editions/tw5.com-server --listen``
+
+この手順を実行すると、通常の方法`npm install -g tiddlywiki`でインストールした場合と同じように、[[npm]]経由でTiddlyWiki5を操作できるようになります。
+
+最新のコードを確実に取得するために、クローンを定期的に更新してください。
diff --git a/editions/ja-JP/tiddlers/nodejs/Installing custom plugins on Node.js.tid b/editions/ja-JP/tiddlers/nodejs/Installing custom plugins on Node.js.tid
new file mode 100644
index 000000000..c7c9b4da4
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Installing custom plugins on Node.js.tid
@@ -0,0 +1,23 @@
+created: 20191022095653896
+modified: 20250122105447127
+original-modified: 20220617130125173
+tags: [[TiddlyWiki on Node.js]] PluginsCS
+title: Installing custom plugins on Node.js
+ja-title: Node.jsにカスタムプラグインをインストールする
+type: text/vnd.tiddlywiki
+
+\rules except wikilink
+
+! 紹介
+
+Node.jsクライアントサーバー構成でTiddlyWikiを使用する場合、公式プラグインとカスタムプラグインをインストールするにはいくつかの方法があります。
+
+注記
+<$macrocall $name=".note" _="""ライブラリから単一ファイルWikiにプラグインをインストールする手順については、[[プラグイン|Plugins]]で詳細を確認してください。
+"""/>
+
+
+!! プラグインのロード順序
+
+{{Plugin Ordering}}
+
diff --git a/editions/ja-JP/tiddlers/nodejs/Installing official plugins on Node.js.tid b/editions/ja-JP/tiddlers/nodejs/Installing official plugins on Node.js.tid
new file mode 100644
index 000000000..e9882cfa3
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Installing official plugins on Node.js.tid
@@ -0,0 +1,41 @@
+created: 20220611123344385
+modified: 20250123113223702
+original-modified: 20220617132351460
+tags: [[TiddlyWiki on Node.js]] PluginsCS
+title: Installing official plugins on Node.js
+ja-title: Node.jsに公式プラグインをインストールする
+type: text/vnd.tiddlywiki
+
+クライアント-サーバーNode.js構成でTiddlyWikiを使用する場合は、次の手順に従ってください:
+
+# <>の''プラグイン''タブを使用してインストールするプラグインを特定します。(ただし、ここからプラグインをインストール''しないで''ください)
+#* プラグインは、その種類(言語、テーマ、プラグイン)と発行元、タイトルによって識別されます。たとえば、`$:/plugins/tiddlywiki/internals`プラグインは''tiddlywiki/internals''として参照されます
+
+# サーバーが実行中の場合は終了します
+
+# `tiddlywiki.info`ファイル(JSON形式)を編集し、`plugins`、`themes`、`languages`セクションを見つけます(下記参照)
+
+# 追加したいプラグインに対応するエントリを追加します
+#* 項目を区切る''カンマ''を残すように注意してください
+#* リストの最後の項目をコンマで終わらせ''ないで''ください
+
+# サーバーを再起動します
+
+```
+{
+ "plugins": [
+ "tiddlywiki/codemirror"
+ ],
+ "themes": [
+ "tiddlywiki/vanilla",
+ "tiddlywiki/snowwhite"
+ ],
+ "languages": [
+ "es-ES",
+ "fr-FR",
+ "en-EN"
+ ]
+}
+```
+
+<$macrocall $name=".note" _="プラグインの操作の概要については、[[プラグイン|Plugins]]を参照してください。 また、[[Node.jsにカスタムプラグインをインストールする|Installing custom plugins on Node.js]]も参照してください。"/>
diff --git a/editions/ja-JP/tiddlers/nodejs/Scripts for TiddlyWiki on Node.js.tid b/editions/ja-JP/tiddlers/nodejs/Scripts for TiddlyWiki on Node.js.tid
new file mode 100644
index 000000000..e663fa11c
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Scripts for TiddlyWiki on Node.js.tid
@@ -0,0 +1,52 @@
+created: 20131219100637788
+modified: 20250124112753177
+original-modified: 20141015165343893
+tags: [[TiddlyWiki on Node.js]]
+title: Scripts for TiddlyWiki on Node.js
+ja-title: Node.js上のTiddlyWiki用スクリプト
+type: text/vnd.tiddlywiki
+
+! スクリプトファイル
+
+TiddlyWiki5リポジトリの`bin`フォルダーには、共通のタスクを自動化したり、独自のスクリプトの便利な開始点として使用したりできるスクリプトがいくつか含まれています。https://tiddlywiki.com/ の構築とリリースに使用されるスクリプトの詳細については、[[Scripts for building tiddlywiki.com]]を参照してください。
+
+すべてのスクリプトは、リポジトリのルートフォルダーから実行されることを想定しています。
+
+!! `serve`: tw5.comを提供する
+
+```
+./bin/serve.sh -h
+./bin/serve.sh [edition dir] [username] [password] [host] [port]
+```
+
+または:
+
+```
+./bin/serve.cmd -h
+./bin/serve.cmd [edition dir] [username] [password] [host] [port]
+```
+
+このスクリプトは、TiddlyWiki5をHTTPサーバーとして実行し、`tw5.com-server`エディションのコンテンツをデフォルトにします。デフォルトでは、Node.jsは8080ポート でサービスを提供します。オプションの`username`パラメータが指定されている場合は、編集の署名に使用されます。`password`が指定されている場合は、HTTP基本認証が使用されます。`-h`パラメータを指定してスクリプトを実行すると、オンラインヘルプが表示されます。
+
+この構成を試すには、スクリプトを実行してからブラウザで`http://127.0.0.1:8080`にアクセスしてください。
+
+ブラウザで行われた変更は、HTTP経由でサーバーに伝えられます(これらのリクエストを確認するには、ブラウザ開発者コンソールを使用します)。その後、サーバーは変更をファイルシステムに同期します(各変更をスクリーンに記録します)。
+
+!! `test`: テストをビルドして実行する
+
+This script runs the `test` edition of TiddlyWiki on the server to perform the server-side tests and to build `test.html` for running the tests in the browser.
+このスクリプトは、サーバー側のテストを実行し、ブラウザでテストを実行するために、`test.html`をビルドし、サーバー上でTiddlyWikiの`test`のエディションを実行します。
+
+!! `lazy`: tw5.comを遅延読み込み画像で提供する
+
+```
+./bin/lazy.sh []
+```
+
+または:
+
+```
+./bin/lazy.cmd []
+```
+
+このスクリプトは、画像に[[遅延読み込み|LazyLoading]]を適用して`tw5.com-server`エディションコンテンツを提供します。
diff --git a/editions/ja-JP/tiddlers/nodejs/TiddlyWiki on Node.js.tid b/editions/ja-JP/tiddlers/nodejs/TiddlyWiki on Node.js.tid
new file mode 100644
index 000000000..8b65d1274
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/TiddlyWiki on Node.js.tid
@@ -0,0 +1,24 @@
+created: 20131129094353704
+modified: 20241227105025118
+original-modified: 20220617114433107
+tags: Platforms
+title: TiddlyWiki on Node.js
+ja-title: Node.js上のTiddlyWiki
+type: text/vnd.tiddlywiki
+
+\rules except wikilink
+
+[[Node.js]]でTiddlyWikiを実行すると、単一ファイルバージョンに比べていくつかの重要な利点が得られます:
+
+* 個々のTiddlerは別々のファイルに保存され、必要に応じて整理できます。
+
+* 共有コンテンツと独自コンテンツのさまざまな組み合わせをブレンドした複数のWikiを構築する機能
+
+* スマートフォンやタブレットを含むあらゆる最新ブラウザでコンテンツを編集できます
+
+<<.warning """Node.js上のTiddlyWikiは現在、実行中にファイルシステム経由でTiddlerファイルを直接変更することをサポートしていないことに注意してください。変更を有効にするには、サーバーを再起動する必要があります。実行中の Wikiを編集するには、HTTPやJavaScript APIを使用することをお勧めします。""">>
+
+
+詳細については、以下を参照してください:
+
+<>
diff --git a/editions/ja-JP/tiddlers/nodejs/Uninstalling a plugin with Node.js.tid b/editions/ja-JP/tiddlers/nodejs/Uninstalling a plugin with Node.js.tid
new file mode 100644
index 000000000..7c0707864
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Uninstalling a plugin with Node.js.tid
@@ -0,0 +1,33 @@
+created: 20220611125113040
+modified: 20250204103637098
+original-modified: 20220617133704286
+tags: [[TiddlyWiki on Node.js]] PluginsCS
+title: Uninstalling a plugin with Node.js
+ja-title: Node.jsでプラグインをアンインストールする
+type: text/vnd.tiddlywiki
+
+クライアント-サーバー Node.js構成でTiddlyWikiを使用する場合は、次の手順に従ってください:
+
+# サーバーが実行中の場合は終了します
+
+# `tiddlywiki.info`ファイル(JSON形式)を編集し、`plugins`と`themes`セクションを見つけます(下記参照)
+
+# 削除したいプラグインに対応するエントリを削除します
+#* 項目を区切る''カンマ''を残すように注意してください
+#* リストの最後の項目をコンマで終わらせ''ない''でください
+
+# サーバーを再起動します
+
+```
+{
+ "plugins": [
+ "tiddlywiki/codemirror"
+ ],
+ "themes": [
+ "tiddlywiki/vanilla",
+ "tiddlywiki/snowwhite"
+ ]
+}
+```
+
+<$macrocall $name=".note" _="プラグインの操作方法の概要については、[[プラグイン|Plugins]]で確認できます"/>
diff --git a/editions/ja-JP/tiddlers/nodejs/Upgrading TiddlyWiki on Node.js.tid b/editions/ja-JP/tiddlers/nodejs/Upgrading TiddlyWiki on Node.js.tid
new file mode 100644
index 000000000..8bf5a12ee
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Upgrading TiddlyWiki on Node.js.tid
@@ -0,0 +1,19 @@
+created: 20131219100544073
+modified: 20241228112745930
+original-modified: 20140912141800426
+tags: [[TiddlyWiki on Node.js]]
+title: Upgrading TiddlyWiki on Node.js
+ja-title: Node.js上のTiddlyWikiのアップグレード
+type: text/vnd.tiddlywiki
+
+通常の方法で[[Node.js上のTiddlyWiki|TiddlyWiki on Node.js]]をインストールした場合、新しいバージョンがリリースされたときに、次のコマンドでアップグレードできます:
+
+```
+npm update -g tiddlywiki
+```
+
+MacやLinuxでは、次のように''sudo''を追加する必要があります:
+
+```
+sudo npm update -g tiddlywiki
+```
diff --git a/editions/ja-JP/tiddlers/nodejs/Using TiddlyWiki on Node.js.tid b/editions/ja-JP/tiddlers/nodejs/Using TiddlyWiki on Node.js.tid
new file mode 100644
index 000000000..5d0b6307b
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Using TiddlyWiki on Node.js.tid
@@ -0,0 +1,43 @@
+created: 20131219100520659
+modified: 20250206101730728
+original-modified: 20241025051303991
+tags: [[TiddlyWiki on Node.js]]
+title: Using TiddlyWiki on Node.js
+ja-title: Node.jsでTiddlyWikiを使用する
+type: text/vnd.tiddlywiki
+
+~TiddlyWiki5には、[[TiddlyWikiフォルダ|TiddlyWikiFolders]]、[[Tiddlerファイル|TiddlerFiles]]に基づいて広範な操作を実行するためにコマンドラインで使用するコマンドセットが含まれています。
+
+たとえば、次のコマンドは、~TiddlyWiki HTMLファイルからTiddlerを読み込み、そのうちの1つを静的HTMLに保存します:
+
+```
+tiddlywiki --verbose --load mywiki.html --render ReadMe ./readme.html
+```
+
+コマンドラインから`tiddlywiki`を実行すると、~TiddlyWikiカーネルが起動し、コアプラグインがロードされ、空のWikiストアが確立されます。次に、コマンドライン引数を左から右に順番に処理します。引数はスペースで区切られます。
+
+<<.from-version "5.1.20">> まず、プレフィックス`+`で始まるプラグイン名や、`++`で始まるプラグインフォルダーへのパスによって識別される0個以上のプラグイン参照が存在する可能性があります。これらのプラグインは、[[TiddlyWikiフォルダ|TiddlyWikiFolders]]で指定されたプラグインに加えてロードされます。
+
+次の引数は、ロードする[[TiddlyWikiフォルダ|TiddlyWikiFolders]]へのオプションのパスです。存在しない場合は、現在のディレクトリが使用されます。
+
+コマンドとそれぞれの引数は以下のように示されます。各コマンドはプレフィックス`--`で識別されます。
+
+```
+tiddlywiki [+ | ++] [] [-- [[,]]]
+```
+
+例えば:
+
+```
+tiddlywiki --version
+tiddlywiki +plugins/tiddlywiki/filesystem +plugins/tiddlywiki/tiddlyweb mywiki --listen
+tiddlywiki ++./mygreatplugin mywiki --listen
+```
+
+<<.from-version "5.1.18">> 多数のパラメータをサポートするListenCommandなどのコマンドでは、[[名前付きコマンドパラメータ|NamedCommandParameters]]を使用して扱いやすくすることができます。例:
+
+```
+tiddlywiki wikipath --listen username=jeremy port=8090
+```
+
+使用可能なコマンドの完全なリストについては、[[コマンド|Commands]]を参照してください。
diff --git a/editions/ja-JP/tiddlers/nodejs/Working with the TiddlyWiki5 repository.tid b/editions/ja-JP/tiddlers/nodejs/Working with the TiddlyWiki5 repository.tid
new file mode 100644
index 000000000..8f8d4c39b
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/Working with the TiddlyWiki5 repository.tid
@@ -0,0 +1,25 @@
+created: 20131219100444289
+modified: 20250206103847601
+original-modified: 20140920134404247
+tags: [[TiddlyWiki on Node.js]]
+title: Working with the TiddlyWiki5 repository
+ja-title: TiddlyWiki5リポジトリの操作
+type: text/vnd.tiddlywiki
+
+! 紹介
+
+TiddlyWikiの開発に[[貢献|Contributing]]したい場合は、[[通常の方法でTiddlyWikiをインストールする|Installing TiddlyWiki on Node.js]]のではなく、GitHubリポジトリを直接動かすことができます。
+
+Mario Pietschが[[短い紹介動画|Working with the TiddlyWiki5 repository video]]を作成しました。
+
+! セットアップ
+
+# GitHubのアカウントをお持ちでない場合は、アカウントを作成してください
+# https://github.com/TiddlyWiki/TiddlyWiki5 からTiddlyWiki5 GitHubリポジトリをフォークします
+# フォークのローカルコピーをクローンします
+# コマンドラインターミナルを開き、現在の作業ディレクトリをリポジトリのルートに変更します
+# `npm link` (Windows)か`sudo npm link` (Mac/Linux)と入力して、[[npm]]にこのリポジトリのコピーをグローバルにインストールされたものとして使用するように指示します
+
+この手順を実行すると、`npm install -g tiddlywiki`による通常の方法でインストールした場合と同じように、[[npm]]経由でTiddlyWiki5を操作できるようになります。
+
+[[Node.js上のTiddlyWiki用スクリプト|Scripts for TiddlyWiki on Node.js]]も参照してください。
diff --git a/editions/ja-JP/tiddlers/nodejs/tiddlywiki.files_Files.tid b/editions/ja-JP/tiddlers/nodejs/tiddlywiki.files_Files.tid
new file mode 100644
index 000000000..fcebf9c5e
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/tiddlywiki.files_Files.tid
@@ -0,0 +1,172 @@
+created: 20161015114118243
+modified: 20250201104758596
+original-modified: 20211114101256212
+tags: TiddlyWikiFolders [[TiddlyWiki on Node.js]]
+title: tiddlywiki.files Files
+ja-title: tiddlywiki.filesファイル
+type: text/vnd.tiddlywiki
+
+! 紹介
+
+[[TiddlyWikiフォルダ|TiddlyWikiFolders]]内のサブフォルダーにあるJSONファイル`tiddlywiki.files`は、フォルダーを再帰的にスキャンしてTiddlerファイルを探す通常のロジックをオーバーライドします。代わりに、`tiddlywiki.files`ファイルは特定のファイルとフォルダーからTiddlerをロードするための指示を指定します。
+
+ファイルの形式は、2つのオプションプロパティを持つオブジェクトです:
+
+* ''tiddlers'' - ファイルから読み取ったフィールドを上書きや変更する機能を持つ外部ファイルを記述するオブジェクトの配列
+* ''directories'' - 外部ディレクトリを記述するオブジェクトの配列、それらのディレクトリ内のどのファイルを処理すべきかを決定するフィルターと、ファイルから読み取ったフィールドのいずれかを上書きや変更する機能
+
+`tiddlywiki.files`の処理に大幅な機能強化が[[リリース 5.1.14|Release 5.1.14]]で導入されたことに注意してください。
+
+!! フィールドのオーバーライド
+
+`tiddlywiki.files`ファイルの''tiddlers''セクションと''directories''セクションの両方に、`fields`オブジェクトを使用してフィールドの値を上書きやカスタマイズする機能が含まれています。
+
+各フィールドは、フィールドに直接割り当てられる''文字列''や''配列''値として指定することも、<<.from-version "5.1.14">>フィールドの値を生成する方法を説明する''オブジェクト''として指定することもできます。オブジェクトには次のプロパティが含まれます:
+
+* ''source'' - (オプション) フィールドのソース値を指定する文字列。指定しない場合は、既存の値が使用されます
+** //filename// Tiddlerを含むファイルのファイル名
+** //filename-uri-decoded// [[URIデコード|https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent]]を適用した、Tiddlerを含むファイルのファイル名
+** //basename// 拡張子なしのTiddlerを含むファイルのファイル名
+** //basename-uri-decoded// [[URIデコード|https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent]]を適用した、拡張子なしのTiddlerを含むファイルのファイル名
+** //extname// Tiddlerを含むファイル名の拡張子
+** //created// Tiddlerを含むファイルの作成日時
+** //modified// Tiddlerを含むファイルの更新日時
+** <<.from-version "5.3.0">> //filepath// ディレクトリの''path''プロパティを基準とした、Tiddlerを含むファイルのパス(''directories''宣言でのみ使用可能)
+** <<.from-version "5.3.0">> //subdirectories// ディレクトリの''path''プロパティを基準とした、ファイルの相対パス内のサブディレクトリの配列(''directories''宣言でのみ使用可能)
+* ''prefix'' - (オプション) フィールドの値の先頭に追加する文字列
+* ''suffix'' - (オプション) フィールドの値の末尾に追加する文字列
+
+! Tiddlersセクション
+
+`tiddlers`配列内のファイルの仕様は、次のプロパティをサポートします:
+
+* ''file'': (必須) Tiddlerデータを含むファイルへの絶対パスまたは相対パス (相対パスは`tiddlywiki.files`ファイルのパスを基準とします)
+* ''isTiddlerFile'': (オプション) `true`の場合、ファイルは[[tiddlerファイル|TiddlerFiles]]として扱われ、Tiddlerを抽出するためにデシリアライズされます。それ以外の場合は、ファイルの生のコンテンツが解析されずに`text`フィールドに割り当てられます
+* ''fields'': (オプション) Tiddlerファイルで提供されるフィールドを上書きやカスタマイズする値を含むオブジェクト (上記を参照)
+* ''prefix''と''suffix'': (オプション) Tiddlerの`text`フィールドにプレフィックスとサフィックスとして付加される文字列
+*> ''prefix''を指定することは、''fields''オブジェクトの`text`のフィールドを`{"prefix":""}`に設定することと同じであることに注意してください。
+
+! Directoriesセクション
+
+`directories`配列内のディレクトリの仕様は次の形式を取ることができます:
+
+* Tiddlerファイルを含むディレクトリへの絶対パスか相対パスを指定する、''string''リテラル(相対パスは`tiddlywiki.files`ファイルのパスを基準として解釈されます)。Tiddlerファイルはディレクトリを再帰的に検索されます
+* <<.from-version "5.1.14">> 次のプロパティを持つ''object'':
+** ''path'' - (必須) Tiddlerファイルを含むディレクトリへの絶対パスか相対パス(相対パスは`tiddlywiki.files`ファイルのパスを基準として解釈されます)。デフォルトではディレクトリは再帰的に検索されないことに注意してください。//searchSubdirectories//フラグが`true`に設定されていない限り、サブディレクトリは無視されます(以下を参照)。
+** ''filesRegExp'' - (オプション) ディレクトリ内で処理するファイルのファイル名に一致する[[正規表現|https://developer.mozilla.org/en/docs/Web/JavaScript/Guide/Regular_Expressions]]
+** ''isTiddlerFile'' - (必須) `true`の場合、ファイルは[[Tiddlerファイル|TiddlerFiles]]として扱われ、Tiddlerを抽出するためにデシリアライズされます。それ以外の場合、ファイルの生のコンテンツが解析されずに`text`フィールドに割り当てられます
+** ''isEditableFile'' - <<.from-version "5.1.23">> (オプション) `true`の場合、Tiddlerへの変更は元のファイルに保存されます。Tiddlerは、$:/config/FileSystemPathフィルターから結果が生成されない限り、元のファイルパスに保存されます。フィルターから結果が返された場合、生成された最終的なファイルパスが上書きされます。
+** ''searchSubdirectories'' - <<.from-version "5.1.23">> (オプション) `true`の場合、//path//のすべてのサブディレクトリで(オプションの)//filesRegExp//に一致するファイルが再帰的に検索されます。//filesRegExp//が指定されていない場合は、//path//のすべてのサブディレクトリ内のすべてのファイルがロードされます。//source//属性の//filename//(上記を参照)によって生成されたTiddlerタイトルにはファイル名のみが含まれ、パスのサブディレクトリは含まれません。この結果、同じTiddlerタイトルでロードされた複数のファイルが存在する場合、そのTiddlerタイトルでロードされた最後のファイルのみがメモリに格納されます。これを防ぐには、//filename//の代わりに//filepath//属性を使用できます。または、複数のディレクトリオブジェクトを含め、//source//属性とともに//prefix//または//suffix//を使用してタイトルフィールドをカスタマイズすることもできます。
+** ''fields'' - (必須) Tiddlerファイルで提供されるフィールドを上書きやカスタマイズする値を含むオブジェクト(上記を参照)
+
+同じ名前にサフィックス`.meta`を加えたファイルを作成することで、特定のファイルのフィールドを上書きすることもできます。 -- TiddlerFilesを参照してください。
+
+! 例
+
+これらの`tiddlywiki.files`の例は、[[Wikiフォルダ|TiddlyWikiFolders]]の独自のサブディレクトリに配置する必要があります。
+
+メインの[[TiddlyWiki 5 GitHub リポジトリ|https://github.com/TiddlyWiki/TiddlyWiki5]]にも`tiddlywiki.files`ファイルの例がいくつかあります。
+
+!! PDFのフォルダをインポートする
+
+この例では、相対パスで指定されたフォルダーから拡張子`.pdf`を持つすべてのファイルを取得します。このパスは"../../../"で始まり、この構成ファイルが格納されているフォルダーの3ディレクトリ階層上を示します。各Tiddlerは、次のフィールドを使用してLazyLoading用にセットアップされています:
+
+* ''title'' - PDFファイルのURIデコードされたベースファイル名を設定。[[URIデコード|https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent]]により、"/"などの文字をURIエンコードして"%2F"としてタイトルに含めることができます
+* ''created'' - PDFファイルの作成日時を設定
+* ''modified'' - PDFファイルの変更日時を設定
+* ''type'' - `application/pdf`を設定
+* ''tags'' - `$:/tags/AttachedFile`を設定
+* ''text'' - 空の文字列を設定
+* ''_canonical_uri'' - ファイル名と文字列"pdfs/"を連結した値を設定
+
+```
+{
+ "directories": [
+ {
+ "path": "../../../input/pdfs",
+ "filesRegExp": "^.*\\.pdf$",
+ "isTiddlerFile": false,
+ "fields": {
+ "title": {"source": "basename-uri-decoded"},
+ "created": {"source": "created"},
+ "modified": {"source": "modified"},
+ "type": "application/pdf",
+ "tags": ["$:/tags/AttachedFile"],
+ "text": "",
+ "_canonical_uri": {"source": "filename", "prefix": "pdfs/"}
+ }
+ }
+ ]
+}
+```
+
+!! テキストファイルのフォルダをインポートする
+
+この例では、相対パスで指定されたフォルダから拡張子`.txt`を持つすべてのファイルを取得します。このフォルダはWikiのベースディレクトリ内にあり、現在の構成ファイルはWikiの"tiddlers/"ディレクトリ内のディレクトリにあります。したがって、この場合、パスは"../../"で始まり、2つのディレクトリ階層上に移動し、次に "externalnotes/"ディレクトリまで下ります。各Tiddlerは次のフィールドで設定されます:
+
+* ''title'' - テキストファイルのURIデコードされたベースファイル名を設定します。[[URIデコード|https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent]]により、"/"などの文字をURIエンコードして"%2F"としてタイトルに含めることができます
+* ''created'' - テキストファイルの作成日時を設定
+* ''modified'' - テキストファイルの変更日時を設定
+* ''type'' - `text/plain`を設定
+* ''tags'' - `[[note]] [[externalnote]] [[.txt]]`を設定(配列表記を使用)
+* ''text'' - 設定されないため、ファイルの内容がテキストフィールドとして読み込まれます
+
+```
+{
+ "directories": [
+ {
+ "path": "../../externalnotes",
+ "filesRegExp": ".+\\.txt",
+ "isTiddlerFile": false,
+ "isEditableFile": true,
+ "fields": {
+ "title": {"source": "basename-uri-decoded"},
+ "created": {"source": "created"},
+ "modified": {"source": "modified"},
+ "type": "text/plain",
+ "tags": ["note", "externalnote", ".txt"]
+ }
+ }
+ ]
+}
+```
+
+これにより、`../../externalnotes/`ディレクトリ内のすべてのテキストファイルが個別のTiddlerとしてWikiに読み込まれます。これらは、さまざまなマークアップ言語のスニペットコレクションである可能性があります。次に、これらの各Tiddlerの`type`フィールドを、言語に合わせて変更できます。たとえば、Wikitextの場合は"text/vnd.tiddlywiki"、マークダウンファイルの場合は"text/markdown"です。次に、次の行で$:/config/FileSystemPathsと$:/config/FileSystemExtentions Tiddlerを使用すると、これらのTiddlerへの変更が、開始元のディレクトリに保存され、"*.txt"ファイルとして、"*.txt.meta"ファイルとともに保存されます。これらのメタファイルは必要に応じて生成され、サーバーの再起動時に、`tiddlywiki.files`構成ファイルから生成されたフィールド(Tiddlerの`type`フィールドなど)が上書きされます。
+
+[[Tiddlerファイル名のカスタマイズ|Customising Tiddler File Naming]]の例から、$:/config/FileSystemPaths Tiddler内の最後のフィルター`[!tag[externalnote]addprefix[wiki/]]`は、`externalnotes`でタグ付けされたすべてのTiddler(以前のフィルターに一致しなかったもの)を除外することがわかります。これらのTiddlerのファイルパスは、ブート起動時に生成された$:/config/OriginalTiddlerPathsから取得されます。
+
+次に、$:/config/FileSystemExtensions Tiddler内のフィルター`[tag[.txt]then[.txt]]`により、これらすべてのTiddlerが*.txtおよび付随する*.txt.metaファイルとしてディスクに保存されます(通常のTiddlerタイプとファイルタイプのマッピングを上書きします)。この場合、Tiddlywiki Wikitextやマークダウンテキストのスニペットを"テキスト"(*.txtファイル)に保存できるようになります。
+
+!! 画像のインポートと自動タグ付け
+
+この例では、`files`ディレクトリとそのすべてのサブディレクトリ内のすべての画像ファイルを外部画像Tiddlerとしてインポートし、ファイルパスに基づいてタグ付けします。各Tiddlerには、次のフィールドが設定されます:
+
+* ''title'' - テキストファイルのURIデコードされたベースファイル名を設定
+* ''created'' - テキストファイルの作成日時を設定
+* ''modified'' - テキストファイルの更新日時を設定
+* ''type'' - `image/jpeg`に設定します。現在、ファイルから画像Tiddlerの正しいContentTypeを推測する方法はありませんが、`image/jpeg`Tiddlerはpngやgif画像でも正しくレンダリングされるはずです。代わりに、jpg、png、gifファイルの個別の定義を、`image/jpeg`、`image/png`、`image/gif`タイプをそれぞれ使用して作成することもできます。
+* ''tags'' - 親ディレクトリ(この場合は`files`)を基準とした画像の相対パスに基づいて生成されます。たとえば、`files/photos`内の画像には`photos`のタグが付けられ、 `files/photos/family`内の画像には`photos`と`family`両方のタグが付けられ、ルート`files`ディレクトリ内の画像にはタグが付けられません。
+* ''text'' - 空の文字列に設定
+* ''_canonical_uri'' - Wikiルートを基準とした画像の完全な相対ファイルパスを設定
+
+```
+{
+ "directories": [
+ {
+ "path": "../../files/",
+ "filesRegExp": "^.*\\.(?:jpg|jpeg|png|gif)$",
+ "isTiddlerFile": false,
+ "searchSubdirectories": true,
+ "fields": {
+ "title": {"source": "basename-uri-decoded"},
+ "created": {"source": "created"},
+ "modified": {"source": "modified"},
+ "type": "image/jpeg",
+ "tags": { "source": "subdirectories" },
+ "text": "",
+ "_canonical_uri": { "source": "filepath", "prefix": "files/" }
+ }
+ }
+ ]
+}
+```
diff --git a/editions/ja-JP/tiddlers/nodejs/tiddlywiki.info_Files.tid b/editions/ja-JP/tiddlers/nodejs/tiddlywiki.info_Files.tid
new file mode 100644
index 000000000..c6a32f9d7
--- /dev/null
+++ b/editions/ja-JP/tiddlers/nodejs/tiddlywiki.info_Files.tid
@@ -0,0 +1,60 @@
+created: 20161015114042793
+modified: 20250201105445142
+original-modified: 20241030132156792
+tags: TiddlyWikiFolders [[TiddlyWiki on Node.js]]
+title: tiddlywiki.info Files
+ja-title: tiddlywiki.infoファイル
+type: text/vnd.tiddlywiki
+
+[[TiddlyWikiフォルダ|TiddlyWikiFolders]]はWikiフォルダーのルートにある1つの`tiddlywiki.info`ファイルで構成されます。このファイルには、次のプロパティを含むJSONオブジェクトが含まれている必要があります:
+
+* ''plugins'' - Wikiに含めるプラグインの配列
+* ''themes'' - Wikiに含めるテーマの配列
+* ''languages'' - Wikiに含める言語の配列
+* ''includeWikis'' - Wikiに含める外部Wikiフォルダへの参照の配列
+* ''build'' - 名前付きビルドターゲットのハッシュマップ。それぞれはコマンドトークンの配列で定義されます(BuildCommandを参照)
+* ''config'' - 設定オプションのオプションのハッシュマップ(下記参照)
+
+!!! ''includeWikis''
+
+''includeWikis''配列のエントリは、Wikiへの相対パスを指定する文字列か、次のフィールドを持つオブジェクトのいずれかになります:
+
+* ''path'' - Wikiフォルダへの相対パス
+* ''read-only'' - //true//に設定すると、含まれているWiki内のTiddlerが変更されるのを防ぎます。変更は、以下で説明する''default-tiddler-location''で指定されたディレクトリに書き込まれます
+
+!!! ''build''
+
+現在の`tiddlywiki.info`ファイルでその名前のターゲットが定義されていない場合、含まれているWikiのビルドターゲットはマージされることに注意してください。
+
+!!! ''config''
+
+構成オプションには以下が含まれます:
+
+* ''default-tiddler-location'' - ファイルシステムアダプタが新しいTiddlerを保存するためのデフォルトの場所への文字列パス(Wikiフォルダを基準に解決)
+* ''retain-original-tiddler-path'' - trueの場合、サーバーはWiki内の各Tiddlerの元のファイルパスを含むティドラー[[$:/config/OriginalTiddlerPaths]]を生成します
+
+!!! 例
+
+例:
+
+```
+{
+ "plugins": [
+ "tiddlywiki/tiddlyweb",
+ "tiddlywiki/filesystem"
+ ],
+ "includeWikis": [
+ {"path": "../tw5.com", "read-only": true}
+ ],
+ "build": {
+ "index": [
+ "--render","$:/core/save/all","index.html","text/plain"],
+ "favicon": [
+ "--save", "$:/favicon.ico", "favicon.ico",
+ "--save", "$:/green_favicon.ico", "static/favicon.ico"]
+ },
+ "config": {
+ "retain-original-tiddler-path": true
+ }
+}
+```
diff --git a/editions/ja-JP/tiddlers/platforms/Platforms.tid b/editions/ja-JP/tiddlers/platforms/Platforms.tid
new file mode 100644
index 000000000..ac0b4598e
--- /dev/null
+++ b/editions/ja-JP/tiddlers/platforms/Platforms.tid
@@ -0,0 +1,12 @@
+created: 20150412185300152
+modified: 20241227104147434
+original-modified: 20150412185427211
+tags: TableOfContents
+title: Platforms
+ja-title: プラットフォーム
+type: text/vnd.tiddlywiki
+
+
+TiddlyWikiはいくつかのプラットフォームで使用できます:
+
+<>
\ No newline at end of file
diff --git a/editions/ja-JP/tiddlers/plugins/Plugin Ordering.tid b/editions/ja-JP/tiddlers/plugins/Plugin Ordering.tid
new file mode 100644
index 000000000..4495d351a
--- /dev/null
+++ b/editions/ja-JP/tiddlers/plugins/Plugin Ordering.tid
@@ -0,0 +1,49 @@
+created: 20220613115453346
+modified: 20250207104327815
+original-modified: 20220628160136158
+tags: PluginMechanism
+title: Plugin Ordering
+ja-title: プラグインの順序
+type: text/vnd.tiddlywiki
+
+Node.jsクライアント-サーバー構成を使用すると、プラグインは次の順序でアクティブになります:
+
+# OS環境変数を使用して見つかったプラグイン
+#* 参照: [[PluginFolders]]
+#* および: [[Node.jsの環境変数|Environment Variables on Node.js]]
+
+# Wiki`/plugins`パスに保存されたプラグイン
+#* 参照: [[PluginFolders]]
+
+# コマンドラインで指定されたプラグイン
+#* 参照: [[Node.jsでTiddlyWikiを使用する|Using TiddlyWiki on Node.js]] ... <<.from-version "5.1.20">>に関する注記
+
+# ドラッグアンドドロップでWikiコンテンツとしてインポートされたプラグイン
+#* 参照: [[プラグインライブラリからプラグインをインストールする|Installing a plugin from the plugin library]]や[[プラグインを手動でインストールする|Manually installing a plugin]]
+
+''重要:''
+
+* ''リストの下位の要素が優先されます''
+
+*ブラウザにドラッグアンドドロップして通常のTiddlerとしてプラグインを追加すると、プラグインはブラウザ内でのみアクティブになります
+** Node.js下では利用できません
+
+オプション 1:
+
+* Node.js構成を使用する場合、オプション1が最も一般的な方法です
+* すべてのプラグインを一度に更新できるため、メンテナンスの手間が軽減されます
+
+オプション 2:
+
+* 構成を固定して作業したい場合はオプション2が推奨されます
+* プラグインの更新は対応するWikiにのみ影響します
+
+オプション 3:
+
+* このオプションを使用すると、既存の`tiddlywiki.info`ファイルを上書きすることなくエディションを''追加して開始''できます
+* tiddlywiki.infoファイルで指定されていない場合でも、任意のエディションをクライアント-サーバーエディションとして起動できます。
+
+オプション 4:
+
+* 単一ファイルのWikiで使用されるのと全く同じメカニズムです
+* このメカニズムは、プラグインが`tiddlers/`ディレクトリに保存されるため、Node.js構成では''テストとデバッグ''の目的でのみ使用する必要があります
diff --git a/editions/ja-JP/tiddlers/saving/Example config-tiddlyweb-host for IIS.txt b/editions/ja-JP/tiddlers/saving/Example config-tiddlyweb-host for IIS.txt
new file mode 100644
index 000000000..e30d38eb6
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example config-tiddlyweb-host for IIS.txt
@@ -0,0 +1,2 @@
+title: $:/config/tiddlyweb/host
+text: $protocol$//$host$/MyApp/
diff --git a/editions/ja-JP/tiddlers/saving/Example config-tiddlyweb-host for IIS.txt.meta b/editions/ja-JP/tiddlers/saving/Example config-tiddlyweb-host for IIS.txt.meta
new file mode 100644
index 000000000..9db7aae2a
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example config-tiddlyweb-host for IIS.txt.meta
@@ -0,0 +1,7 @@
+title: Example config-tiddlyweb-host for IIS
+ja-title: IISのconfig-tiddlyweb-hostの例
+created: 20180328145039530
+modified: 20250123113649343
+original-modified: 20180328145234871
+tags: [[Installing TiddlyWiki on Microsoft Internet Information Server]]
+type: text/plain
diff --git a/editions/ja-JP/tiddlers/saving/Example package.json for IIS.txt b/editions/ja-JP/tiddlers/saving/Example package.json for IIS.txt
new file mode 100644
index 000000000..bfe3b8c1a
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example package.json for IIS.txt
@@ -0,0 +1,8 @@
+{
+ "name": "MyStuff",
+ "description": "A description of this wiki",
+ "dependencies": {
+ "sax": "1.2.4",
+ "tiddlywiki": "*"
+ }
+}
\ No newline at end of file
diff --git a/editions/ja-JP/tiddlers/saving/Example package.json for IIS.txt.meta b/editions/ja-JP/tiddlers/saving/Example package.json for IIS.txt.meta
new file mode 100644
index 000000000..c3bd2e378
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example package.json for IIS.txt.meta
@@ -0,0 +1,7 @@
+created: 20180328145039530
+modified: 20250123114135455
+original-modified: 20180328145234871
+tags: [[Installing TiddlyWiki on Microsoft Internet Information Server]]
+title: Example package.json for IIS
+ja-title: IISのpackage.jsonの例
+type: text/plain
diff --git a/editions/ja-JP/tiddlers/saving/Example tiddlywiki.info for IIS.txt b/editions/ja-JP/tiddlers/saving/Example tiddlywiki.info for IIS.txt
new file mode 100644
index 000000000..1ba78a6c9
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example tiddlywiki.info for IIS.txt
@@ -0,0 +1,11 @@
+{
+ "description": "My wiki",
+ "plugins": [
+ "tiddlywiki/tiddlyweb",
+ "tiddlywiki/filesystem"
+ ],
+ "themes": [
+ "tiddlywiki/vanilla",
+ "tiddlywiki/snowwhite"
+ ]
+}
diff --git a/editions/ja-JP/tiddlers/saving/Example tiddlywiki.info for IIS.txt.meta b/editions/ja-JP/tiddlers/saving/Example tiddlywiki.info for IIS.txt.meta
new file mode 100644
index 000000000..c4f5b3389
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example tiddlywiki.info for IIS.txt.meta
@@ -0,0 +1,7 @@
+created: 20180328151124878
+modified: 20250123114435480
+original-modified: 20180328151214616
+tags: [[Installing TiddlyWiki on Microsoft Internet Information Server]]
+title: Example tiddlywiki.info for IIS
+ja-title: IISのtiddlywiki.infoの例
+type: text/plain
diff --git a/editions/ja-JP/tiddlers/saving/Example web.config for IIS.txt b/editions/ja-JP/tiddlers/saving/Example web.config for IIS.txt
new file mode 100644
index 000000000..d8a75bb4f
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example web.config for IIS.txt
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/editions/ja-JP/tiddlers/saving/Example web.config for IIS.txt.meta b/editions/ja-JP/tiddlers/saving/Example web.config for IIS.txt.meta
new file mode 100644
index 000000000..6fa8afd4f
--- /dev/null
+++ b/editions/ja-JP/tiddlers/saving/Example web.config for IIS.txt.meta
@@ -0,0 +1,7 @@
+created: 20180328145259455
+modified: 20250123114732207
+original-modified: 20180701185215523
+tags: [[Installing TiddlyWiki on Microsoft Internet Information Server]]
+title: Example web.config for IIS
+ja-title: IISのweb.configの例
+type: text/plain
diff --git a/editions/prerelease/tiddlers/Release 5.3.7.tid b/editions/prerelease/tiddlers/Release 5.3.7.tid
index 312808704..1644c9300 100644
--- a/editions/prerelease/tiddlers/Release 5.3.7.tid
+++ b/editions/prerelease/tiddlers/Release 5.3.7.tid
@@ -15,6 +15,7 @@ description: Under development
* French
* German
+* Japanese
! Plugin Improvements
@@ -31,7 +32,8 @@ description: Under development
* <<.link-badge-added "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8783"> (and <<.link-badge-here "https://github.com/TiddlyWiki/TiddlyWiki5/commit/028c80782d105beb90f5d58a7f22e865c7e8c6f4">>) [[Hidden Setting: Default Type for Missing Tiddlers]]
* <<.link-badge-added "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8661">> DiffTextWidget colours to several core palettes
-* <<.link-badge-improved "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8807">> Flexoki palette with additional colours
+* <<.link-badge-improved "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8807">> (and <<.link-badge-here "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8911">>) Flexoki palette with additional colours
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8837">> [[incorrect|https://localizejs.com/articles/why-using-flag-icons-can-confuse-your-users/]] use of national flags to represent languages
! Hackability Improvements
@@ -40,11 +42,29 @@ description: Under development
* <<.link-badge-extended "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8816">> 'disabled' attribute to SelectWidget and BrowseWidget
* <<.link-badge-extended "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8819">> 'tabindex' attribute to BrowseWidget, RangeWidget, CheckboxWidget and RadioWidget
* <<.link-badge-updated "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8821">> the editor link dropdown to use newer syntax
+* <<.link-badge-added "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8911">> support for images in AVIF format
+* <<.link-badge-added "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8912">> support for custom MIME types to the [[WidgetMessage: tm-copy-to-clipboard]]
! Bug Fixes
* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8800">> problem with overwriting shadow tiddlers from plugins that do not have a `plugin-priority` field
* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8831">> (and <<.link-badge-here "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8835">>) problem with switching language not correctly updating the `lang` attribute of the root `` element
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/issues/8842">> bug with refreshing ExternalImages with a `_canonical_uri` field
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8882">> [[unusedtitle Macro]] to trim whitespace from the generated title
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8898">> file extensions and MIME types for font files
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8903">> bug where the wiki would be marked as dirty when a shadow tiddler is changed
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8895">> unnecessary refresh with GenesisWidget
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/commit/d4bc3fcd998902c17cd6bcefdc8d380e5c224458">> [[WidgetMessage: tm-http-request]] to pass custom variables to the progress actions
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8930">> FillWidget to no longer display its content
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/issues/8921">> inconsistent whitespace in page toolbar "More" dropdown
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8931">> RSOD with [[contains Operator]] if created field is accessed
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/issues/8881">> incorrect .html file extension of exported tiddlers on Android
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8951">> Arabic text using sans-serif font by adding "system-ui" to default font family
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/issues/8955">> refresh problem with "save" button
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8721">> [[list-tagged-draggable Macro]] to use the "caption" field if available
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/pull/8959">> problem with missing expandable arrow in [[toc-selective-expandable|Table-of-Contents Macros]]
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/issues/5930">> the default value does not working for the CheckboxWidget if it is bound to an index in a data tiddler
+* <<.link-badge-fixed "https://github.com/TiddlyWiki/TiddlyWiki5/issues/8970">> [[median Operator]] to order values as numbers, not strings
! Node.js Improvements
@@ -60,12 +80,19 @@ description: Under development
<<.contributors """
DesignThinkerer
+flibbles
+galenhuntington
IchijikuIchigo
+jeremyredhead
jrbntt
+jryans
Leilei332
linonetwo
michaeljmcd
+opn
pmario
+Rhys-T
+saqimtiaz
well-noted
xcazin
""">>
diff --git a/editions/test/tiddlers/tests/data/transclude/CustomWidget-RawAndSlotted.tid b/editions/test/tiddlers/tests/data/transclude/CustomWidget-RawAndSlotted.tid
new file mode 100644
index 000000000..a8e6feb68
--- /dev/null
+++ b/editions/test/tiddlers/tests/data/transclude/CustomWidget-RawAndSlotted.tid
@@ -0,0 +1,34 @@
+title: Transclude/CustomWidget/RawAndSlotted
+description: Custom widget can mix ts-raw and custom slots
+type: text/vnd.tiddlywiki-multiple
+tags: [[$:/tags/wiki-test-spec]]
+
+title: Output
+
+\whitespace trim
+\widget $my.widget()
+\whitespace trim
+<$slot $name="ts-header">
+ Default Header
+$slot>
+-
+<$slot $name="ts-raw"/>
+\end
+<$my.widget>
+ First Body
+$my.widget>
+
+
+<$my.widget>
+ <$fill $name="ts-header">
+ Custom Header
+ $fill>
+ <$fill $name="ts-never">
+ <$log RawAndSlotted="Transclude/CustomWidget/RawAndSlotted is actually failing. $fill slots are executing silently when they weren't invoked." />
+ $fill>
+ Second Body
+$my.widget>
++
+title: ExpectedResult
+
+
Default Header-First Body
Custom Header-Second Body
\ No newline at end of file
diff --git a/editions/test/tiddlers/tests/modules/utils/test-csv.js b/editions/test/tiddlers/tests/modules/utils/test-csv.js
index b53e9b289..3556235ec 100644
--- a/editions/test/tiddlers/tests/modules/utils/test-csv.js
+++ b/editions/test/tiddlers/tests/modules/utils/test-csv.js
@@ -6,9 +6,6 @@ tags: [[$:/tags/test-spec]]
Tests the backlinks mechanism.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe('CSV Parsing', function() {
@@ -29,5 +26,3 @@ describe('CSV Parsing', function() {
})
});
-
-})();
diff --git a/editions/test/tiddlers/tests/test-action-widgets.js b/editions/test/tiddlers/tests/test-action-widgets.js
index 9d706e1a3..f8a7ddea0 100644
--- a/editions/test/tiddlers/tests/test-action-widgets.js
+++ b/editions/test/tiddlers/tests/test-action-widgets.js
@@ -6,7 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the action widgets.
\*/
-(function(){
+
/* jslint node: true, browser: true */
/* eslint-env node, browser, jasmine */
@@ -94,5 +94,3 @@ it("should handle the action-listops widget", function() {
});
-})();
-
diff --git a/editions/test/tiddlers/tests/test-backlinks.js b/editions/test/tiddlers/tests/test-backlinks.js
index ea7c2b7b4..c02f9b1c7 100644
--- a/editions/test/tiddlers/tests/test-backlinks.js
+++ b/editions/test/tiddlers/tests/test-backlinks.js
@@ -6,9 +6,6 @@ tags: [[$:/tags/test-spec]]
Tests the backlinks mechanism.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe('Backlinks tests', function() {
@@ -141,5 +138,3 @@ describe('Backlinks tests', function() {
});
});
});
-
-})();
diff --git a/editions/test/tiddlers/tests/test-backtranscludes.js b/editions/test/tiddlers/tests/test-backtranscludes.js
index afc09af4e..52f08d970 100644
--- a/editions/test/tiddlers/tests/test-backtranscludes.js
+++ b/editions/test/tiddlers/tests/test-backtranscludes.js
@@ -6,9 +6,6 @@ tags: $:/tags/test-spec
Tests the backtranscludes mechanism.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe('Backtranscludes and transclude filter tests', function() {
@@ -253,5 +250,3 @@ describe('Backtranscludes and transclude filter tests', function() {
});
});
});
-
-})();
diff --git a/editions/test/tiddlers/tests/test-checkbox-widget.js b/editions/test/tiddlers/tests/test-checkbox-widget.js
index f42a269a9..83ed66421 100644
--- a/editions/test/tiddlers/tests/test-checkbox-widget.js
+++ b/editions/test/tiddlers/tests/test-checkbox-widget.js
@@ -6,7 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the checkbox widget thoroughly.
\*/
-(function(){
+
/*jslint node: true, browser: true */
/*global $tw: false */
@@ -78,6 +78,13 @@ Tests the checkbox widget thoroughly.
startsOutChecked: false,
expectedChange: { "TiddlerOne": { expand: "yes" } }
},
+ {
+ testName: "field mode default when missing -> true",
+ tiddlers: [],
+ widgetText: "<$checkbox tiddler='TiddlerOne' field='expand' default='yes' checked='yes' unchecked='no' />",
+ startsOutChecked: true,
+ expectedChange: { "TiddlerOne": { expand: "no" } }
+ },
{
testName: "field mode indeterminate -> true",
tiddlers: [{title: "TiddlerOne", text: "Jolly Old World", expand: "some other value"}],
@@ -98,19 +105,28 @@ Tests the checkbox widget thoroughly.
var indexModeTests = fieldModeTests.map(data => {
var newData = {...data};
var newName = data.testName.replace('field mode', 'index mode');
+ var tiddlerOneAlreadyExists = false;
var newTiddlers = data.tiddlers.map(tiddler => {
+ if(tiddler.title === "TiddlerOne") {
+ tiddlerOneAlreadyExists = true;
+ }
return {title: tiddler.title, type: "application/x-tiddler-dictionary", text: `one: a\nexpand: ${tiddler.expand}\ntwo: b`}
});
var newWidgetText = data.widgetText.replace("field='expand'", "index='expand'");
var newChange = {};
for (var key of Object.keys(data.expectedChange)) {
var oldChange = data.expectedChange[key];
- if (oldChange.expand) {
- newChange[key] = { text: `one: a\nexpand: ${oldChange.expand}\ntwo: b` }
+ var text;
+ if (!tiddlerOneAlreadyExists) {
+ // If it wasn't there, the created one will be JSON
+ text = `{\n "expand": "${oldChange.expand}"\n}`;
+ } else if (oldChange.expand) {
+ text = `one: a\nexpand: ${oldChange.expand}\ntwo: b`;
} else {
// In index tiddlers, the "expand" field gets completely removed, not turned into "expand: (undefined)"
- newChange[key] = { text: `one: a\ntwo: b` }
+ text = `one: a\ntwo: b`;
}
+ newChange[key] = { text: text };
}
newData.testName = newName;
newData.tiddlers = newTiddlers;
@@ -514,7 +530,9 @@ Tests the checkbox widget thoroughly.
/*
* Checkbox widget tests using the test data above
*/
- for (var data of checkboxTestData) {
+ // MAKE SURE TO USE $tw.utils.each HERE!!!
+ // If you use a forloop, the closure of the tests will all use the last value "data" was assigned to, and thus all run the same test.
+ $tw.utils.each(checkboxTestData, function(data) {
it('checkbox widget test: ' + data.testName, function() {
// Setup
@@ -553,9 +571,8 @@ Tests the checkbox widget thoroughly.
}
}
})
- }
+ });
});
-})();
\ No newline at end of file
diff --git a/editions/test/tiddlers/tests/test-compare-filter.js b/editions/test/tiddlers/tests/test-compare-filter.js
index b146fcc18..1fedf890c 100644
--- a/editions/test/tiddlers/tests/test-compare-filter.js
+++ b/editions/test/tiddlers/tests/test-compare-filter.js
@@ -6,7 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the compare filter.
\*/
-(function(){
+
/* jslint node: true, browser: true */
/* eslint-env node, browser, jasmine */
@@ -81,4 +81,3 @@ describe("'compare' filter tests", function() {
});
-})();
diff --git a/editions/test/tiddlers/tests/test-deserialize-operator.js b/editions/test/tiddlers/tests/test-deserialize-operator.js
index c629de3ae..cc465dfbb 100644
--- a/editions/test/tiddlers/tests/test-deserialize-operator.js
+++ b/editions/test/tiddlers/tests/test-deserialize-operator.js
@@ -6,7 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests deserialize[] filter operator with various core deserializers
\*/
-(function(){
+
/* jslint node: true, browser: true */
/* eslint-env node, browser, jasmine */
@@ -37,8 +37,4 @@ Tests deserialize[] filter operator with various core deserializers
});
});
-})();
-
-
-
\ No newline at end of file
diff --git a/editions/test/tiddlers/tests/test-deserializers.js b/editions/test/tiddlers/tests/test-deserializers.js
index ae652cdfe..d207debf1 100644
--- a/editions/test/tiddlers/tests/test-deserializers.js
+++ b/editions/test/tiddlers/tests/test-deserializers.js
@@ -6,7 +6,6 @@ tags: [[$:/tags/test-spec]]
Tests various core deserializers
\*/
-(function(){
/* jslint node: true, browser: true */
/* eslint-env node, browser, jasmine */
@@ -34,6 +33,3 @@ Tests various core deserializers
executeTestCase("dezerializer test data case 5",[ { title: 'Hello "There"', text: 'Abacus', type: 'text/vnd.tiddlywiki' }, { title: 'Hello "There"', text: 'Calculator'} , { title: 'Hello "There"', text: 'Protractor'} ]);
});
-
- })();
-
\ No newline at end of file
diff --git a/editions/test/tiddlers/tests/test-fakedom.js b/editions/test/tiddlers/tests/test-fakedom.js
index 7041f017b..faec01af6 100644
--- a/editions/test/tiddlers/tests/test-fakedom.js
+++ b/editions/test/tiddlers/tests/test-fakedom.js
@@ -7,9 +7,6 @@ Tests the fakedom that Tiddlywiki occasionally uses.
\*/
(function(){
-
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("fakedom tests", function() {
diff --git a/editions/test/tiddlers/tests/test-filters.js b/editions/test/tiddlers/tests/test-filters.js
index 727f64ca4..96100e2f7 100644
--- a/editions/test/tiddlers/tests/test-filters.js
+++ b/editions/test/tiddlers/tests/test-filters.js
@@ -6,12 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the filtering mechanism.
\*/
-(function(){
- /* jslint node: true, browser: true */
- /* eslint-env node, browser, jasmine */
- /* eslint no-mixed-spaces-and-tabs: ["error", "smart-tabs"]*/
- /* global $tw, require */
"use strict";
describe("Filter tests", function() {
@@ -1134,9 +1129,17 @@ Tests the filtering mechanism.
expect(wiki.filterTiddlers("[[<>:\"/\\|?*]encodeuricomponent[]]").join(",")).toBe("%3C%3E%3A%22%2F%5C%7C%3F%2A");
});
+ it("should handle the moduleproperty operator", function() {
+ // We don't need to confirm them all, only it it finds at least one module name that we're sure is there.
+ expect(wiki.filterTiddlers("[[macro]modules[]moduleproperty[name]]")).toContain("qualify");
+ // No such property. Nothing to return.
+ expect(wiki.filterTiddlers("[[macro]modules[]moduleproperty[nonexistent]]").length).toBe(0);
+ // No such tiddlers. Nothing to return.
+ expect(wiki.filterTiddlers("[[nonexistent]moduleproperty[name]]").length).toBe(0);
+ // Non string properties should get toStringed.
+ expect(wiki.filterTiddlers("[[$:/core/modules/commands/init.js]moduleproperty[info]]").join(" ")).toBe('{"name":"init","synchronous":true}');
+ });
}
});
- })();
-
diff --git a/editions/test/tiddlers/tests/test-html-parser.js b/editions/test/tiddlers/tests/test-html-parser.js
index d2266ca5e..9fc108235 100644
--- a/editions/test/tiddlers/tests/test-html-parser.js
+++ b/editions/test/tiddlers/tests/test-html-parser.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests for the internal components of the HTML tag parser
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
function FakeParser() {
@@ -231,5 +228,3 @@ describe("HTML tag new parser tests", function() {
});
});
-
-})();
diff --git a/editions/test/tiddlers/tests/test-json-filters.js b/editions/test/tiddlers/tests/test-json-filters.js
index bfb8a4504..566f77fe2 100644
--- a/editions/test/tiddlers/tests/test-json-filters.js
+++ b/editions/test/tiddlers/tests/test-json-filters.js
@@ -6,7 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the JSON filters and the format:json operator
\*/
-(function(){
+
/* jslint node: true, browser: true */
/* eslint-env node, browser, jasmine */
@@ -151,4 +151,3 @@ describe("json filter tests", function() {
});
-})();
diff --git a/editions/test/tiddlers/tests/test-linked-list.js b/editions/test/tiddlers/tests/test-linked-list.js
index de477257d..20150bc80 100644
--- a/editions/test/tiddlers/tests/test-linked-list.js
+++ b/editions/test/tiddlers/tests/test-linked-list.js
@@ -21,10 +21,7 @@ NOTE TO FURTHER LINKED LIST DEVELOPERS:
the end. I think you'll probably be better off preventing 'prev' from ever
adding undefined.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("LinkedList class tests", function() {
@@ -307,4 +304,3 @@ describe("LinkedList class tests", function() {
});
});
-})();
diff --git a/editions/test/tiddlers/tests/test-parsetextreference.js b/editions/test/tiddlers/tests/test-parsetextreference.js
index 59f885232..3c18b90fb 100644
--- a/editions/test/tiddlers/tests/test-parsetextreference.js
+++ b/editions/test/tiddlers/tests/test-parsetextreference.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests for source attribute in parser returned from wiki.parseTextReference
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Wiki.parseTextReference tests", function() {
@@ -129,4 +126,3 @@ describe("Wiki.parseTextReference tests", function() {
});
-})();
diff --git a/editions/test/tiddlers/tests/test-plugins.js b/editions/test/tiddlers/tests/test-plugins.js
index 8e79efe24..fadf92a10 100644
--- a/editions/test/tiddlers/tests/test-plugins.js
+++ b/editions/test/tiddlers/tests/test-plugins.js
@@ -7,9 +7,6 @@ Tests for integrity of the core plugins, languages, themes and editions
\*/
(function(){
-
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
if($tw.node) {
diff --git a/editions/test/tiddlers/tests/test-popup.js b/editions/test/tiddlers/tests/test-popup.js
index 455da2b9b..fe6dac2c4 100644
--- a/editions/test/tiddlers/tests/test-popup.js
+++ b/editions/test/tiddlers/tests/test-popup.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests some utility function of the Popup prototype.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Popup tests", function() {
@@ -60,4 +57,3 @@ describe("Popup tests", function() {
});
});
-})();
diff --git a/editions/test/tiddlers/tests/test-prefixes-filter.js b/editions/test/tiddlers/tests/test-prefixes-filter.js
index a8d109d73..c71d32585 100644
--- a/editions/test/tiddlers/tests/test-prefixes-filter.js
+++ b/editions/test/tiddlers/tests/test-prefixes-filter.js
@@ -4,7 +4,7 @@ type: application/javascript
tags: [[$:/tags/test-spec]]
Tests the reduce prefix and filter.
\*/
-(function(){
+
/* jslint node: true, browser: true */
/* eslint-env node, browser, jasmine */
@@ -459,5 +459,3 @@ describe("'reduce' and 'intersection' filter prefix tests", function() {
expect(wiki.filterTiddlers('[tag[shopping]] :reduce[]',anchorWidget).join(",")).toBe(" 0 Brownies, 1 Chick Peas, 2 Milk, 3 Rice Pudding,");
});
});
-
-})();
\ No newline at end of file
diff --git a/editions/test/tiddlers/tests/test-tags-operator.js b/editions/test/tiddlers/tests/test-tags-operator.js
index 87970d113..4fa0b5963 100644
--- a/editions/test/tiddlers/tests/test-tags-operator.js
+++ b/editions/test/tiddlers/tests/test-tags-operator.js
@@ -6,8 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the tagging mechanism.
\*/
-/*jslint node: true, browser: true */
-/*global $tw: false */
+
"use strict";
describe("Tags Operator tests", function() {
diff --git a/editions/test/tiddlers/tests/test-tags.js b/editions/test/tiddlers/tests/test-tags.js
index 563c39fe5..2032db039 100644
--- a/editions/test/tiddlers/tests/test-tags.js
+++ b/editions/test/tiddlers/tests/test-tags.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the tagging mechanism.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Tag tests", function() {
@@ -179,4 +176,3 @@ function runTests(wiki,wikiOptions) {
});
-})();
diff --git a/editions/test/tiddlers/tests/test-tiddler.js b/editions/test/tiddlers/tests/test-tiddler.js
index f85ee9c6a..070ca98dc 100644
--- a/editions/test/tiddlers/tests/test-tiddler.js
+++ b/editions/test/tiddlers/tests/test-tiddler.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the tiddler object
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Tiddler tests", function() {
@@ -134,4 +131,3 @@ describe("Tiddler tests", function() {
});
-})();
diff --git a/editions/test/tiddlers/tests/test-utils.js b/editions/test/tiddlers/tests/test-utils.js
index 91ddf86f4..29fa99c01 100644
--- a/editions/test/tiddlers/tests/test-utils.js
+++ b/editions/test/tiddlers/tests/test-utils.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests various utility functions.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Utility tests", function() {
@@ -210,5 +207,3 @@ describe("Utility tests", function() {
});
});
-
-})();
\ No newline at end of file
diff --git a/editions/test/tiddlers/tests/test-widget-event.js b/editions/test/tiddlers/tests/test-widget-event.js
new file mode 100644
index 000000000..b70f5424c
--- /dev/null
+++ b/editions/test/tiddlers/tests/test-widget-event.js
@@ -0,0 +1,224 @@
+/*\
+title: test-widget-event.js
+type: application/javascript
+tags: [[$:/tags/test-spec]]
+\*/
+(function(){
+
+/*jslint node: true, browser: true */
+/*global $tw: false */
+"use strict";
+
+describe("Widget Event Listeners", function() {
+ var widget = require("$:/core/modules/widgets/widget.js");
+
+ function createWidgetNode(parseTreeNode,wiki,parentWidget) {
+ return new widget.widget(parseTreeNode,{
+ wiki: wiki,
+ document: $tw.fakeDocument,
+ parentWidget: parentWidget
+ });
+ }
+
+ it("should call all added event listeners on dispatchEvent", function() {
+ var calls = [];
+ var wiki = new $tw.Wiki();
+ var widget = createWidgetNode({type:"widget", text:"text"}, wiki);
+
+ // Add a function listener.
+ widget.addEventListener("testEvent", function(e) {
+ calls.push("funcListener");
+ return true;
+ });
+ // Setup a method on widget for string listener.
+ widget.testHandler = function(e) {
+ calls.push("methodListener");
+ return true;
+ };
+ widget.addEventListener("testEvent", "testHandler");
+
+ var event = {type:"testEvent"};
+ var result = widget.dispatchEvent(event);
+ expect(result).toBe(true);
+ expect(calls.length).toBe(2);
+ expect(calls).toContain("funcListener");
+ expect(calls).toContain("methodListener");
+ });
+
+ it("should remove an event listener correctly", function() {
+ var calls = [];
+ var wiki = new $tw.Wiki();
+ var widget = createWidgetNode({type:"widget", text:"text"}, wiki);
+
+ function listener(e) {
+ calls.push("listener");
+ return true;
+ }
+ // Add listener twice: once as function and then add another distinct listener.
+ widget.addEventListener("removeTest", listener);
+ widget.addEventListener("removeTest", function(e) {
+ calls.push("secondListener");
+ return true;
+ });
+ // Remove the function listener.
+ widget.removeEventListener("removeTest", listener);
+
+ var event = {type:"removeTest"};
+ var result = widget.dispatchEvent(event);
+ expect(result).toBe(true);
+ expect(calls.length).toBe(1);
+ expect(calls).toContain("secondListener");
+ expect(calls).not.toContain("listener");
+ });
+
+ it("stop further propagation by returns false won't block other listeners on the same level.", function() {
+ var calls = [];
+ var wiki = new $tw.Wiki();
+ var widget = createWidgetNode({type:"widget", text:"text"}, wiki);
+
+ widget.addEventListener("stopEvent", function(e) {
+ calls.push("first");
+ // stops further propagation, but still dispatch event for second listener.
+ return false;
+ });
+ widget.addEventListener("stopEvent", function(e) {
+ calls.push("second");
+ return true;
+ });
+ var event = {type:"stopEvent"};
+ var result = widget.dispatchEvent(event);
+ expect(result).toBe(false);
+ expect(calls.length).toBe(2);
+ expect(calls).toContain("first");
+ expect(calls).toContain("second");
+ });
+
+ it("should dispatch event to parent widget if not handled on child", function() {
+ var parentCalls = [];
+ var wiki = new $tw.Wiki();
+ var parentWidget = createWidgetNode({type:"widget", text:"text"}, wiki);
+ parentWidget.addEventListener("parentEvent", function(e) {
+ parentCalls.push("parentListener");
+ return true;
+ });
+ // Create a child with parentWidget assigned.
+ var childWidget = createWidgetNode({type:"widget", text:"text"}, wiki, parentWidget);
+ // No listener on child; so dispatch should bubble up.
+ var event = {type:"parentEvent"};
+ var result = childWidget.dispatchEvent(event);
+ expect(result).toBe(true);
+ expect(parentCalls.length).toBe(1);
+ expect(parentCalls).toContain("parentListener");
+ });
+
+ it("should not dispatch event to parent if child's listener stops propagation", function() {
+ var parentCalls = [];
+ var wiki = new $tw.Wiki();
+ var parentWidget = createWidgetNode({type:"widget", text:"text"}, wiki);
+ parentWidget.addEventListener("bubbleTest", function(e) {
+ parentCalls.push("parentListener");
+ return true;
+ });
+ var childWidget = createWidgetNode({type:"widget", text:"text"}, wiki, parentWidget);
+ childWidget.addEventListener("bubbleTest", function(e) {
+ return false; // Stop event propagation
+ });
+ var event = {type:"bubbleTest"};
+ var result = childWidget.dispatchEvent(event);
+ expect(result).toBe(false);
+ expect(parentCalls.length).toBe(0);
+ });
+
+ it("should call multiple listeners in proper order across child and parent", function() {
+ var calls = [];
+ var wiki = new $tw.Wiki();
+ var parentWidget = createWidgetNode({type:"widget", text:"text"}, wiki);
+ parentWidget.addEventListener("chainEvent", function(e) {
+ calls.push("parentListener");
+ return true;
+ });
+ var childWidget = createWidgetNode({type:"widget", text:"text"}, wiki, parentWidget);
+ childWidget.addEventListener("chainEvent", function(e) {
+ calls.push("childListener");
+ return true;
+ });
+ var event = {type:"chainEvent"};
+ var result = childWidget.dispatchEvent(event);
+ expect(result).toBe(true);
+ expect(calls.length).toBe(2);
+ // First call from child widget and then parent's listener.
+ expect(calls[0]).toBe("childListener");
+ expect(calls[1]).toBe("parentListener");
+ });
+
+ // Additional tests for multiple event types
+ it("should handle events of different types separately", function() {
+ var callsA = [];
+ var callsB = [];
+ var wiki = new $tw.Wiki();
+ var widget = createWidgetNode({type:"widget", text:"text"}, wiki);
+ widget.addEventListener("eventA", function(e) {
+ callsA.push("A1");
+ return true;
+ });
+ widget.addEventListener("eventB", function(e) {
+ callsB.push("B1");
+ return true;
+ });
+ widget.dispatchEvent({type:"eventA"});
+ widget.dispatchEvent({type:"eventB"});
+ expect(callsA).toContain("A1");
+ expect(callsB).toContain("B1");
+ });
+
+ // Test using $tw.utils.each in removeEventListener internally (behavior verified via dispatch)
+ it("should remove listeners using $tw.utils.each without affecting other listeners", function() {
+ var calls = [];
+ var wiki = new $tw.Wiki();
+ var widget = createWidgetNode({type:"widget", text:"text"}, wiki);
+ function listener1(e) {
+ calls.push("listener1");
+ return true;
+ }
+ function listener2(e) {
+ calls.push("listener2");
+ return true;
+ }
+ widget.addEventListener("testRemove", listener1);
+ widget.addEventListener("testRemove", listener2);
+ widget.removeEventListener("testRemove", listener1);
+ widget.dispatchEvent({type:"testRemove"});
+ expect(calls.length).toBe(1);
+ expect(calls).toContain("listener2");
+ expect(calls).not.toContain("listener1");
+ });
+
+ it("should prevent adding the same event listener multiple times", function() {
+ var calls = 0;
+ var wiki = new $tw.Wiki();
+ var widget = createWidgetNode({type:"widget", text:"text"}, wiki);
+
+ function listener(e) {
+ calls++;
+ return true;
+ }
+
+ // Add the same listener multiple times
+ widget.addEventListener("testEvent", listener);
+ widget.addEventListener("testEvent", listener);
+ widget.addEventListener("testEvent", listener);
+
+ // Dispatch the event
+ var event = {type:"testEvent"};
+ widget.dispatchEvent(event);
+
+ // The listener should only be called once
+ expect(calls).toBe(1);
+
+ // Check the internal structure of eventListeners array
+ expect(widget.eventListeners["testEvent"].length).toBe(1);
+ });
+
+});
+
+})();
diff --git a/editions/test/tiddlers/tests/test-widget-getVariableInfo.js b/editions/test/tiddlers/tests/test-widget-getVariableInfo.js
index 7273a6dce..4ce21a956 100644
--- a/editions/test/tiddlers/tests/test-widget-getVariableInfo.js
+++ b/editions/test/tiddlers/tests/test-widget-getVariableInfo.js
@@ -7,9 +7,6 @@ Tests the wikitext rendering pipeline end-to-end. We also need tests that indivi
\*/
(function(){
-
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Widget module", function() {
diff --git a/editions/test/tiddlers/tests/test-widget.js b/editions/test/tiddlers/tests/test-widget.js
index e8fbf5e51..87ed3860e 100755
--- a/editions/test/tiddlers/tests/test-widget.js
+++ b/editions/test/tiddlers/tests/test-widget.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the wikitext rendering pipeline end-to-end. We also need tests that individually test parsers, rendertreenodes etc., but this gets us started.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Widget module", function() {
@@ -945,4 +942,3 @@ describe("Widget module", function() {
});
});
-})();
diff --git a/editions/test/tiddlers/tests/test-wikitext-parser.js b/editions/test/tiddlers/tests/test-wikitext-parser.js
index 269ade507..75d23a6b7 100644
--- a/editions/test/tiddlers/tests/test-wikitext-parser.js
+++ b/editions/test/tiddlers/tests/test-wikitext-parser.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests for wikitext parser
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("WikiText parser tests", function() {
@@ -420,4 +417,3 @@ describe("WikiText parser tests", function() {
});
});
-})();
diff --git a/editions/test/tiddlers/tests/test-wikitext-tabs-macro.js b/editions/test/tiddlers/tests/test-wikitext-tabs-macro.js
index 973f6fe66..16e93d73a 100644
--- a/editions/test/tiddlers/tests/test-wikitext-tabs-macro.js
+++ b/editions/test/tiddlers/tests/test-wikitext-tabs-macro.js
@@ -9,10 +9,7 @@ Intended to permit future readability improvements.
Adding new functionality will probably change the "expected" html structure.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("Tabs-macro HTML tests", function() {
@@ -81,4 +78,3 @@ describe("Tabs-macro HTML tests", function() {
});
});
-})();
diff --git a/editions/test/tiddlers/tests/test-wikitext.js b/editions/test/tiddlers/tests/test-wikitext.js
index 0f17ec0fc..264d6e00e 100644
--- a/editions/test/tiddlers/tests/test-wikitext.js
+++ b/editions/test/tiddlers/tests/test-wikitext.js
@@ -6,10 +6,7 @@ tags: [[$:/tags/test-spec]]
Tests the wikitext rendering pipeline end-to-end. We also need tests that individually test parsers, rendertreenodes etc., but this gets us started.
\*/
-(function(){
-/*jslint node: true, browser: true */
-/*global $tw: false */
"use strict";
describe("WikiText tests", function() {
@@ -71,4 +68,3 @@ describe("WikiText tests", function() {
});
});
-})();
diff --git a/editions/translators/tiddlers/Extracting Translations.tid b/editions/translators/tiddlers/Extracting Translations.tid
index 3fe559e10..c29d7a40e 100644
--- a/editions/translators/tiddlers/Extracting Translations.tid
+++ b/editions/translators/tiddlers/Extracting Translations.tid
@@ -12,7 +12,6 @@ Use this procedure if the language being submitted is not already present in the
# Create the new language folder `languages/xx-XX`
# Copy the language files into the language folder
# Create a `plugin.info` file for the translation
-# Create an appropriate flag image in `icon.tid`
# Add the new language to tw5.com
# Submit a pull request
diff --git a/editions/tw5.com/tiddlers/Tags.tid b/editions/tw5.com/tiddlers/Tags.tid
new file mode 100644
index 000000000..b77f0d452
--- /dev/null
+++ b/editions/tw5.com/tiddlers/Tags.tid
@@ -0,0 +1,8 @@
+created: 20250211093401937
+modified: 20250211093527189
+tags: Concepts
+title: Tags
+
+Tags are used to organise tiddlers into categories.
+
+For more details see: [[Tagging]]
\ No newline at end of file
diff --git a/editions/tw5.com/tiddlers/Title.tid b/editions/tw5.com/tiddlers/Title.tid
new file mode 100644
index 000000000..cd89fb6dc
--- /dev/null
+++ b/editions/tw5.com/tiddlers/Title.tid
@@ -0,0 +1,8 @@
+created: 20250211094052630
+modified: 20250211094419548
+tags: Concepts
+title: Title
+
+The minimum requirement for a valid tiddler is a ''unique'' title.
+
+Learn more at: [[Tiddlers]]
\ No newline at end of file
diff --git a/editions/tw5.com/tiddlers/about/Developers.tid b/editions/tw5.com/tiddlers/about/Developers.tid
index 7ec64f20e..084869ae9 100644
--- a/editions/tw5.com/tiddlers/about/Developers.tid
+++ b/editions/tw5.com/tiddlers/about/Developers.tid
@@ -22,8 +22,3 @@ There are several resources for developers to learn more about TiddlyWiki and to
*** An enhanced group search facility is available on [[mail-archive.com|https://www.mail-archive.com/tiddlywikidev@googlegroups.com/]]
* Chat at https://gitter.im/TiddlyWiki/public (development room coming soon)
-
-! Twitter
-
-* Follow [[@TiddlyWiki on Twitter|http://twitter.com/#!/TiddlyWiki]] for the latest news
-
diff --git a/editions/tw5.com/tiddlers/community/Articles.tid b/editions/tw5.com/tiddlers/community/Articles.tid
index 8408056cb..729fe539d 100644
--- a/editions/tw5.com/tiddlers/community/Articles.tid
+++ b/editions/tw5.com/tiddlers/community/Articles.tid
@@ -4,7 +4,7 @@ tags: Community
title: Articles
type: text/vnd.tiddlywiki
-Here are some recent articles written about ~TiddlyWiki. Submit new articles via GitHub, Twitter or by posting in the [[TiddlyWiki Groups|Forums]].
+Here are some recent articles written about ~TiddlyWiki. Submit new articles via GitHub or by posting in the [[TiddlyWiki Groups|Forums]].
diff --git a/editions/tw5.com/tiddlers/community/Examples.tid b/editions/tw5.com/tiddlers/community/Examples.tid
index 100cb8dba..1846613b9 100644
--- a/editions/tw5.com/tiddlers/community/Examples.tid
+++ b/editions/tw5.com/tiddlers/community/Examples.tid
@@ -4,7 +4,7 @@ tags: HelloThere Community
title: Examples
type: text/vnd.tiddlywiki
-This collection showcases inspiring and interesting examples of ~TiddlyWiki being used in the wild. Submit new entries to this collection via GitHub, Twitter or by posting in the [[TiddlyWiki Groups|Forums]].
+This collection showcases inspiring and interesting examples of ~TiddlyWiki being used in the wild. Submit new entries to this collection via GitHub or by posting in the [[TiddlyWiki Groups|Forums]].
diff --git a/editions/tw5.com/tiddlers/community/HelpingTiddlyWiki.tid b/editions/tw5.com/tiddlers/community/HelpingTiddlyWiki.tid
index 764f5e5e4..d7d867575 100644
--- a/editions/tw5.com/tiddlers/community/HelpingTiddlyWiki.tid
+++ b/editions/tw5.com/tiddlers/community/HelpingTiddlyWiki.tid
@@ -10,8 +10,6 @@ If you find TiddlyWiki useful, there are lots of ways you can help assure its fu
OpenSource projects like ~TiddlyWiki thrive on the feedback and engagement of users. ~TiddlyWiki becomes more useful to everyone as more and more people use it. So, if you find ~TiddlyWiki useful, spread the word. The best possible way to assure its future is for it to become a hundred times more popular than before.
-* [img[https://img.shields.io/twitter/url/http/tiddlywiki.com.svg?style=social]]
-* Tweet about ~TiddlyWiki: [[I love TiddlyWiki because...|https://twitter.com/intent/tweet?text=I+love+TiddlyWiki+because...&source=tiddlywiki5]]
* [img[https://img.shields.io/github/stars/jermolene/tiddlywiki5.svg?style=social&label=Star]]
* [[Star the TiddlyWiki5 GitHub Repository|https://github.com/TiddlyWiki/TiddlyWiki5]]
* [[Display the TiddlyWiki Poster|https://tiddlywiki.com/poster]]
diff --git a/editions/tw5.com/tiddlers/community/TiddlyWiki Hangouts.tid b/editions/tw5.com/tiddlers/community/TiddlyWiki Hangouts.tid
index bf5806667..380f0451d 100644
--- a/editions/tw5.com/tiddlers/community/TiddlyWiki Hangouts.tid
+++ b/editions/tw5.com/tiddlers/community/TiddlyWiki Hangouts.tid
@@ -4,7 +4,7 @@ tags: Community Videos
title: TiddlyWiki Hangouts
type: text/vnd.tiddlywiki
-The TiddlyWiki community has held many Google Hangouts over the years. They are announced in the [[TiddlyWiki Google group|https://groups.google.com/d/forum/tiddlywiki]] and on the [[TiddlyWiki Twitter account|https://twitter.com/TiddlyWiki]].
+The TiddlyWiki community has held many Google Hangouts over the years. They are announced in the [[TiddlyWiki Google group|https://groups.google.com/d/forum/tiddlywiki]].
Past Hangouts are archived in this ~YouTube playlist:
diff --git a/editions/tw5.com/tiddlers/community/TiddlyWiki on the Web.tid b/editions/tw5.com/tiddlers/community/TiddlyWiki on the Web.tid
index 9168c2f76..36a5503c3 100644
--- a/editions/tw5.com/tiddlers/community/TiddlyWiki on the Web.tid
+++ b/editions/tw5.com/tiddlers/community/TiddlyWiki on the Web.tid
@@ -1,7 +1,7 @@
color: #808
created: 20241009150445080
icon: $:/core/images/link
-list: TalkTiddlyWiki [[TiddlyWiki on YouTube]] [[TiddlyWiki on Reddit]] [[TiddlyWiki on Discord]] [[TiddlyWiki on GitHub]] [[TiddlyWiki on Mastodon]] [[TiddlyWiki on Twitter]] [[TiddlyWiki on Gitter]] [[TiddlyWiki on Open Collective]]
+list: TalkTiddlyWiki [[TiddlyWiki on YouTube]] [[TiddlyWiki on Reddit]] [[TiddlyWiki on Discord]] [[TiddlyWiki on GitHub]] [[TiddlyWiki on Mastodon]] [[TiddlyWiki on Gitter]] [[TiddlyWiki on Open Collective]]
modified: 20241115170824144
tags: Welcome
title: TiddlyWiki on the Web
diff --git a/editions/tw5.com/tiddlers/community/links/TiddlyWiki on Twitter.tid b/editions/tw5.com/tiddlers/community/links/TiddlyWiki on Twitter.tid
deleted file mode 100644
index 643610e61..000000000
--- a/editions/tw5.com/tiddlers/community/links/TiddlyWiki on Twitter.tid
+++ /dev/null
@@ -1,7 +0,0 @@
-title: TiddlyWiki on Twitter
-caption: Twitter
-tags: [[TiddlyWiki on the Web]]
-url: https://twitter.com/TiddlyWiki
-icon: $:/core/images/twitter
-background-color: #1DA1F2
-text-color: #fff
diff --git a/editions/tw5.com/tiddlers/concepts/Concepts.tid b/editions/tw5.com/tiddlers/concepts/Concepts.tid
index e1ab831ac..f2eabfe51 100644
--- a/editions/tw5.com/tiddlers/concepts/Concepts.tid
+++ b/editions/tw5.com/tiddlers/concepts/Concepts.tid
@@ -8,4 +8,4 @@ type: text/vnd.tiddlywiki
These are the concepts underlying TiddlyWiki. Understanding how these ideas fit together is the key to getting the most from TiddlyWiki.
-<>
+<>
diff --git a/editions/tw5.com/tiddlers/concepts/DefaultTiddlers.tid b/editions/tw5.com/tiddlers/concepts/DefaultTiddlers.tid
index 751c01e74..79e24fd69 100644
--- a/editions/tw5.com/tiddlers/concepts/DefaultTiddlers.tid
+++ b/editions/tw5.com/tiddlers/concepts/DefaultTiddlers.tid
@@ -4,9 +4,14 @@ tags: Concepts
title: DefaultTiddlers
type: text/vnd.tiddlywiki
-"Default tiddlers" refers to the list of tiddlers that is opened at startup in the browser if the address bar does not include a [[permalink|PermaLinks]]).
+"Default tiddlers" refers to the list of tiddlers that are opened at startup in the browser if the address bar does not include a [[permalink|PermaLinks]].
-At startup, the text of the system tiddler [[$:/DefaultTiddlers]] is retrieved and evaluated as a [[filter expression|Filter Expression]]. The resulting list of titles is then inserted into the [[story river|Story River]].
+There are two ways default tiddlers can be defined:
-The [[control panel|$:/ControlPanel]] ''info/basics'' tab includes a text box for direct access to [[$:/DefaultTiddlers]].
+* A [[title-list|Title List]] eg: `TiddlerTitle` and `[[Title with spaces]]`
+* [[Filter expressions|Filter Expression], using filter operators eg: `[tag[HelloThere]]`
+
+The resulting list of titles is then inserted into the [[story river|Story River]].
+
+The [[control panel|$:/ControlPanel]] ''-> Info -> Basics -> Default tiddler'' setting includes a text box for direct access to $:/DefaultTiddlers.
diff --git a/editions/tw5.com/tiddlers/concepts/ExternalImages.tid b/editions/tw5.com/tiddlers/concepts/ExternalImages.tid
index 077faedef..a4aaa906a 100644
--- a/editions/tw5.com/tiddlers/concepts/ExternalImages.tid
+++ b/editions/tw5.com/tiddlers/concepts/ExternalImages.tid
@@ -1,5 +1,5 @@
created: 20140610213500000
-modified: 20241030132047048
+modified: 20250217154855572
tags: Concepts Features
title: ExternalImages
type: text/vnd.tiddlywiki
@@ -23,22 +23,28 @@ To manually create an external image just create the tiddler with the appropriat
The following steps are used to create a static HTML file version of a wiki accompanied by an ''images'' folder containing the referenced external images:
# Create image tiddlers in your TiddlyWikiFolders in the usual way
-# Save the images as separate files (by convention, in a subfolder named ''images'')
+# Save the images as separate files (by convention, in a subfolder named ''/images'')
# Externalise the image tiddlers by giving them a ''_canonical_uri'' field
# Save the main HTML file
Note the image files must be saved before they are externalised. Externalising them destroys the ''text'' field within the in-memory copy of the wiki store, meaning that attempts to save them will fail.
-For an example see the ''externalimages'' build target of the demo ''tw5.com'' wiki:
+!! External Image Configuration
+
+For an example create an ''externalimages'' build target in a ''tiddlywiki.info'' file:
```
---save [is[image]] images
---setfield [is[image]] _canonical_uri $:/core/templates/canonical-uri-external-image text/plain
---setfield [is[image]] text "" text/plain
---render $:/core/save/all externalimages.html text/plain
+"build": {
+ "externalimages": [
+ --save [is[image]] images
+ --setfield [is[image]] _canonical_uri $:/core/templates/canonical-uri-external-image text/plain
+ --setfield [is[image]] text "" text/plain
+ --render $:/core/save/all externalimages.html text/plain
+ ]
+}
```
-!! Saving Separate Image Files
+!! Externalising Image Tiddlers
The following `--save` command (see [[SaveCommand]]) can be used to save the images of a wiki into an ''images'' subfolder:
@@ -46,8 +52,6 @@ The following `--save` command (see [[SaveCommand]]) can be used to save the ima
--save [is[image]] images
```
-!! Externalising Image Tiddlers
-
Two `--setfield` commands are used: the first sets the ''_canonical_uri'' field to a URI derived from the title of the tiddler, and the second clears the text field.
```
@@ -65,6 +69,20 @@ The template tiddler [[$:/core/templates/canonical-uri-external-image]] contains
Note that these operations modify the tiddlers in the wiki store and so may affect the operation of subsequent commands.
+!! Node.js Command to Build External Images
+
+The following command will create external images in the `myWiki/output` folder.
+
+```
+tiddlywiki myWiki --build externalimages
+```
+
+On Windows the following command will create external images that are part of the [[tw5.com edition|https://github.com/TiddlyWiki/TiddlyWiki5/blob/master/editions/tw5.com/tiddlywiki.info#L26]]. The files will be created in the output directory.
+
+```
+tiddlywiki .\editions\tw5.com --build index
+```
+
! Using External Images
You can't edit an external image directly in the browser except by changing the URI field to point to a different image.
diff --git a/editions/tw5.com/tiddlers/concepts/Tiddlers.tid b/editions/tw5.com/tiddlers/concepts/Tiddlers.tid
index d086e2f59..420e409ce 100644
--- a/editions/tw5.com/tiddlers/concepts/Tiddlers.tid
+++ b/editions/tw5.com/tiddlers/concepts/Tiddlers.tid
@@ -4,9 +4,9 @@ tags: Concepts
title: Tiddlers
type: text/vnd.tiddlywiki
-Tiddlers are the fundamental units of information in TiddlyWiki. Tiddlers work best when they are as small as possible so that they can be reused by weaving them together in different ways.
+Tiddlers are the fundamental units of information in ~TiddlyWiki. Tiddlers work best when they are as small as possible so that they can be reused by weaving them together in different ways.
-A "tiddler" is an informal British word meaning a small fish, typically a stickleback or a minnow. Other systems have analogous concepts with generic names like "items", "entries", "entities", "nodes" or "records". TiddlyWiki takes the view that it is better to be confusingly distinctive than confusingly generic.
+A "tiddler" is an informal British word meaning a small fish, typically a stickleback or a minnow. Other systems have analogous concepts with generic names like "items", "entries", "entities", "nodes" or "records". ~TiddlyWiki takes the view that it is better to be confusingly distinctive than confusingly generic.
Internally, tiddlers are a list of uniquely named values called fields. The only field that is required is the `title` field, but useful tiddlers also have a `text` field, and some or all of the standard fields listed in TiddlerFields.
diff --git a/editions/tw5.com/tiddlers/definitions/JeremyRuston.tid b/editions/tw5.com/tiddlers/definitions/JeremyRuston.tid
index a63f3df68..1e72c7dc2 100644
--- a/editions/tw5.com/tiddlers/definitions/JeremyRuston.tid
+++ b/editions/tw5.com/tiddlers/definitions/JeremyRuston.tid
@@ -8,8 +8,6 @@ I'm the original inventor of TiddlyWiki. You can hire me through [[Intertwingled
* jeremy (at) jermolene (dot) com
* [[Jermolene on GitHub|https://github.com/Jermolene]]
-* [[Jermolene on GitTip|https://www.gittip.com/Jermolene/]], a micropayment service
-* [[@Jermolene on Twitter|http://twitter.com/#!/jermolene]]
* [[Jermy on LinkedIn|http://www.linkedin.com/in/jermy]]
* [[Jermy on Flickr|http://www.flickr.com/photos/jermy/]]
diff --git a/editions/tw5.com/tiddlers/features/Future Proof.tid b/editions/tw5.com/tiddlers/features/Future Proof.tid
index 44c599b33..f997e003f 100644
--- a/editions/tw5.com/tiddlers/features/Future Proof.tid
+++ b/editions/tw5.com/tiddlers/features/Future Proof.tid
@@ -4,12 +4,12 @@ tags: Features
title: Future Proof
type: text/vnd.tiddlywiki
-From [[Network World|http://www.networkworld.com/article/3028098/open-source-tools/tiddlywiki-a-free-open-source-wiki-revisited.html]] magazine in January 2016:
+From [[Network World|https://www.networkworld.com/article/947618/tiddlywiki-a-free-open-source-wiki-revisited.html]] magazine in January 2016:
<<<
-Way back in the mists of time (actually, January 2009) I [[wrote|http://www.networkworld.com/article/2272104/applications/an-amazing-free-microwiki.html]] about a really cool tool called TiddlyWiki, a “non-linear personal web notebook”. Fast forward to today and I just had an out of body experience: Completely by accident I found a TiddlyWiki that I started when I wrote that piece and it still works!
+Way back in the mists of time (actually, January 2009) I [[wrote|http://www.networkworld.com/article/2272104/applications/an-amazing-free-microwiki.html]] about a really cool tool called ~TiddlyWiki, a “non-linear personal web notebook”. Fast forward to today and I just had an out of body experience: Completely by accident I found a ~TiddlyWiki that I started when I wrote that piece and it still works!
-Finding code that works flawlessly after just two or three years is magical enough but after seven years?! And given that TiddlyWiki is written as a single page Web application and considering how different browsers are now than they were in 2009, the fact that the old version of TiddlyWiki still works is not short of miraculous.
+Finding code that works flawlessly after just two or three years is magical enough but after seven years?! And given that ~TiddlyWiki is written as a single page Web application and considering how different browsers are now than they were in 2009, the fact that the old version of ~TiddlyWiki still works is not short of miraculous.
<<<
TiddlyWiki is designed with the long term needs of its users in mind. Because it is OpenSource and needs no infrastructure, we can be confident that all we'll need to access a ~TiddlyWiki file even in the far future is an ordinary HTML browser. If you're starting to use ~TiddlyWiki at the beginning of your career you can be confident that it will carry you through to retirement.
diff --git a/editions/tw5.com/tiddlers/filters/else Operator.tid b/editions/tw5.com/tiddlers/filters/else Operator.tid
index 83f6dbe7d..392a1b04f 100644
--- a/editions/tw5.com/tiddlers/filters/else Operator.tid
+++ b/editions/tw5.com/tiddlers/filters/else Operator.tid
@@ -13,3 +13,7 @@ type: text/vnd.tiddlywiki
<<.from-version "5.1.20">> See [[Conditional Operators]] for an overview.
<<.operator-examples "else">>
+
+Also see: [[then Operator]] | [[Then Filter Run Prefix]] and [[Else Filter Run Prefix]]
+
+
diff --git a/editions/tw5.com/tiddlers/filters/syntax/Else Filter Run Prefix.tid b/editions/tw5.com/tiddlers/filters/syntax/Else Filter Run Prefix.tid
index dee5fc7be..ecedc3f3b 100644
--- a/editions/tw5.com/tiddlers/filters/syntax/Else Filter Run Prefix.tid
+++ b/editions/tw5.com/tiddlers/filters/syntax/Else Filter Run Prefix.tid
@@ -15,4 +15,6 @@ type: text/vnd.tiddlywiki
[[run|"Filter Run"]]
"""/>
-This prefix has a [[Shortcut Filter Run Prefix]] symbol `~run`
\ No newline at end of file
+This prefix has a [[Shortcut Filter Run Prefix]] symbol `~run`
+
+Also see: [[Then Filter Run Prefix]] | [[then Operator]] and [[else Operator]]
diff --git a/editions/tw5.com/tiddlers/filters/syntax/then Filter Run Prefix.tid b/editions/tw5.com/tiddlers/filters/syntax/then Filter Run Prefix.tid
index b74000b5a..02d8de0bd 100644
--- a/editions/tw5.com/tiddlers/filters/syntax/then Filter Run Prefix.tid
+++ b/editions/tw5.com/tiddlers/filters/syntax/then Filter Run Prefix.tid
@@ -36,3 +36,5 @@ The major difference between the <<.op then>> operator and a <<.op :then>> prefi
[[Then Filter Run Prefix (Examples)]]
+Also see: [[Else Filter Run Prefix]] | [[then Operator]] and [[else Operator]]
+
diff --git a/editions/tw5.com/tiddlers/filters/then Operator.tid b/editions/tw5.com/tiddlers/filters/then Operator.tid
index e4d389a29..77cc4e3ba 100644
--- a/editions/tw5.com/tiddlers/filters/then Operator.tid
+++ b/editions/tw5.com/tiddlers/filters/then Operator.tid
@@ -15,3 +15,5 @@ type: text/vnd.tiddlywiki
<<.tip "The [[Then Filter Run Prefix]] has a similar purpose to the <<.op then>> operator. See its documentation for a comparison of usage.">>
<<.operator-examples "then">>
+
+Also see: [[else Operator]] | [[Then Filter Run Prefix]] and [[Else Filter Run Prefix]]
diff --git a/editions/tw5.com/tiddlers/hellothere/HelloThere.tid b/editions/tw5.com/tiddlers/hellothere/HelloThere.tid
index 046938156..bbbec39f0 100644
--- a/editions/tw5.com/tiddlers/hellothere/HelloThere.tid
+++ b/editions/tw5.com/tiddlers/hellothere/HelloThere.tid
@@ -10,8 +10,11 @@ type: text/vnd.tiddlywiki
Use it to keep your [[to-do list|TaskManagementExample]], to plan an [[essay or novel|"TiddlyWiki for Scholars" by Alberto Molina]], or to organise your wedding. Record every thought that crosses your brain, or build a flexible and responsive website.
-* ~TiddlyWiki lets you choose where to keep your data, guaranteeing that in the decades to come you will [[still be able to use|Future Proof]] the notes you take today.
+* ~TiddlyWiki stores its data and code in a single HTML file, requiring no installs, no external dependencies, just a web browser
+
+* ~TiddlyWiki lets you choose where to keep your data, guaranteeing that in the decades to come you will [[still be able to use|Future Proof]] the notes you take today
* ~TiddlyWiki is infinitely customisable and extensible with many plugins that add new features
* ~TiddlyWiki is the product of a collective of developers, part of an extensive community of users
+
diff --git a/editions/tw5.com/tiddlers/images/external/tiddlywiki.files b/editions/tw5.com/tiddlers/images/external/tiddlywiki.files
deleted file mode 100644
index 340199e41..000000000
--- a/editions/tw5.com/tiddlers/images/external/tiddlywiki.files
+++ /dev/null
@@ -1,202 +0,0 @@
-{
- "tiddlers": [
- {
- "file": "../../../../../languages/ca-ES/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: ca-ES",
- "language": "ca-ES",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/cs-CZ/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: cs-CZ",
- "language": "cs-CZ",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/da-DK/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: da-DK",
- "language": "da-DK",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/de-AT/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: de-AT",
- "language": "de-AT",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/de-DE/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: de-DE",
- "language": "de-DE",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/el-GR/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: el-GR",
- "language": "el-GR",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/en-US/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: en-US",
- "language": "en-US",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/es-ES/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: es-ES",
- "language": "es-ES",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/fr-FR/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: fr-FR",
- "language": "fr-FR",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/hi-IN/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: hi-IN",
- "language": "hi-IN",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/ia-IA/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: ia-IA",
- "language": "ia-IA",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/it-IT/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: it-IT",
- "language": "it-IT",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/ja-JP/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: ja-JP",
- "language": "ja-JP",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/ko-KR/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: ko-KR",
- "language": "ko-KR",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/nl-NL/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: nl-NL",
- "language": "nl-NL",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/pa-IN/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: pa-IN",
- "language": "pa-IN",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/pt-PT/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: pt-PT",
- "language": "pt-PT",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/ru-RU/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: ru-RU",
- "language": "ru-RU",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/sk-SK/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: sk-SK",
- "language": "sk-SK",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/sv-SE/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: sv-SE",
- "language": "sv-SE",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/zh-Hans/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: zh-Hans",
- "language": "zh-Hans",
- "tags": "Language Icon"
- }
- },
- {
- "file": "../../../../../languages/zh-Hant/icon.tid",
- "isTiddlerFile": true,
- "fields": {
- "title": "Language Icon: zh-Hant",
- "language": "zh-Hant",
- "tags": "Language Icon"
- }
- }
- ]
-}
diff --git a/editions/tw5.com/tiddlers/languages/LanguageGallery.tid b/editions/tw5.com/tiddlers/languages/LanguageGallery.tid
deleted file mode 100644
index cdb972095..000000000
--- a/editions/tw5.com/tiddlers/languages/LanguageGallery.tid
+++ /dev/null
@@ -1,25 +0,0 @@
-created: 20151231083708980
-modified: 20211117212723856
-tags: Languages
-title: LanguageGallery Example
-type: text/vnd.tiddlywiki
-
-Here is an example of using the ListWidget and the TranscludeWidget to show a grid of all of Language Icons which are tiddlers [[tagged|Tagging]] <>and <>
-
-
-