mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-27 01:14:44 +00:00
Merge branch 'tiddlywiki-com'
This commit is contained in:
commit
c808764254
@ -1,7 +1,8 @@
|
|||||||
created: 201308291647
|
created: 20130829164700000
|
||||||
modified: 201308291647
|
modified: 20220427171321793
|
||||||
tags: Concepts
|
tags: Concepts
|
||||||
title: DataTiddlers
|
title: DataTiddlers
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
A data tiddler is a miniature database contained within a tiddler.
|
A data tiddler is a miniature database contained within a tiddler.
|
||||||
|
|
||||||
@ -12,22 +13,4 @@ There are two standard formats:
|
|||||||
|
|
||||||
Other formats of tiddler can also be parsed to yield blocks of data that behave like data tiddlers.
|
Other formats of tiddler can also be parsed to yield blocks of data that behave like data tiddlers.
|
||||||
|
|
||||||
Use a TextReference to look up the value of a named property. For example, if a [[DictionaryTiddler|DictionaryTiddlers]] called `MonthDays` contains:
|
See [[JSON in TiddlyWiki]] for an overview.
|
||||||
|
|
||||||
```
|
|
||||||
oct:31
|
|
||||||
nov:30
|
|
||||||
dec:31
|
|
||||||
```
|
|
||||||
|
|
||||||
... then `{{MonthDays##nov}}` will resolve to the value `30`.
|
|
||||||
|
|
||||||
The same is true if `MonthDays` is a [[JSONTiddler|JSONTiddlers]] with the following content:
|
|
||||||
|
|
||||||
```
|
|
||||||
{"oct":31,"nov":30,"dec":31}
|
|
||||||
```
|
|
||||||
|
|
||||||
Note: //It is currently only possible to retrieve data from the immediate properties of the root object of a JSONTiddler.//
|
|
||||||
|
|
||||||
The widgets ActionSetFieldWidget and ActionListopsWidget can manipulate named properties of data tiddlers by indicating the name of the property in the $index attribute. To create or modify a named property with ActionSetFieldWidget, provide a $value attribute. To delete a named property with ActionSetFieldWidget, omit the $value attribute. ActionListopsWidget assigns the named property the list constructed through its $filter and $subfilter attributes.
|
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
created: 20141228094500000
|
created: 20141228094500000
|
||||||
modified: 20180305111822713
|
modified: 20220427171020974
|
||||||
tags: Concepts
|
tags: Concepts
|
||||||
title: DictionaryTiddlers
|
title: DictionaryTiddlers
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
A dictionary tiddler is a [[data tiddler|DataTiddlers]] containing a simple list of `name: value` pairs.
|
A dictionary tiddler is a kind of [[data tiddler|DataTiddlers]] that contains a simple list of `name: value` pairs.
|
||||||
|
|
||||||
Its [[ContentType]] is `application/x-tiddler-dictionary`.
|
Its [[ContentType]] is `application/x-tiddler-dictionary`.
|
||||||
|
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
created: 20141228094500000
|
created: 20141228094500000
|
||||||
modified: 20150221152956000
|
modified: 20220427171219408
|
||||||
tags: Concepts
|
tags: Concepts
|
||||||
title: JSONTiddlers
|
title: JSONTiddlers
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
A JSON tiddler is a [[data tiddler|DataTiddlers]] containing a [[JSON|JavaScript Object Notation]] structure in its `text` field.
|
A JSON tiddler is a [[data tiddler|DataTiddlers]] containing a [[JSON|JavaScript Object Notation]] structure in its `text` field. See [[JSON in TiddlyWiki]] for an overview.
|
||||||
|
|
||||||
Its [[ContentType]] is `application/json`.
|
Its [[ContentType]] is `application/json`.
|
||||||
|
|
||||||
The [[history list|$:/HistoryList]] is a good example of a JSON tiddler.
|
The [[history list|$:/HistoryList]] is an of a JSON tiddler.
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
created: 20150117152418000
|
created: 20150117152418000
|
||||||
modified: 20150124205659000
|
modified: 20220523075540462
|
||||||
tags: Concepts
|
tags: Concepts
|
||||||
title: Title List
|
title: Title List
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
A <<.def "title list">> is a line of text that presents one or more tiddler titles, strung together with a space between each one and the next.
|
A <<.def "title list">> is a line of text that presents one or more tiddler titles, strung together with a space between each one and the next.
|
||||||
|
|
||||||
@ -12,3 +13,5 @@ If a title <<.em contains>> a space, it needs double square brackets around it:
|
|||||||
Title lists are used in various places, including PermaLinks and the ListField.
|
Title lists are used in various places, including PermaLinks and the ListField.
|
||||||
|
|
||||||
They are in fact the simplest case of a [[filter|Filters]], and are thus a way of expressing a [[selection of titles|Title Selection]].
|
They are in fact the simplest case of a [[filter|Filters]], and are thus a way of expressing a [[selection of titles|Title Selection]].
|
||||||
|
|
||||||
|
<<.warning """The [[Title List]] format cannot reliably represent items that contain certain specific character sequences such as `]] `. Thus it should not be used where there is a possibility of such sequences occurring.""">>
|
||||||
|
@ -1,11 +1,7 @@
|
|||||||
created: 20150221152904000
|
created: 20150221152904000
|
||||||
modified: 20150221181720000
|
modified: 20220427170920772
|
||||||
tags: Definitions
|
tags: Definitions
|
||||||
title: JavaScript Object Notation
|
title: JavaScript Object Notation
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
<<.dlink-ex JSON "https://en.wikipedia.org/wiki/JSON">> is a standard plain-text format used for modelling hierarchical structures of objects that contain named fields.
|
<<.dlink-ex JSON "https://en.wikipedia.org/wiki/JSON">> is a standard plain-text format used for modelling hierarchical structures of objects that contain named fields. See [[JSON in TiddlyWiki]] for an overview.
|
||||||
|
|
||||||
DataTiddlers can have JSON content.
|
|
||||||
|
|
||||||
The <<.mlink jsontiddlers>> macro returns tiddler content in JSON format.
|
|
||||||
|
69
editions/tw5.com/tiddlers/features/JSON in TiddlyWiki.tid
Normal file
69
editions/tw5.com/tiddlers/features/JSON in TiddlyWiki.tid
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
title: JSON in TiddlyWiki
|
||||||
|
tags: Features
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
created: 20220427174702859
|
||||||
|
modified: 20220427174702859
|
||||||
|
|
||||||
|
!! Introduction
|
||||||
|
|
||||||
|
JSON (~JavaScript Object Notation) is a standardised text representation for data structures that is widely used for the storage and transfer of data.
|
||||||
|
|
||||||
|
JSON is used in several different contexts in TiddlyWiki. For example:
|
||||||
|
|
||||||
|
* Tiddlers are represented as JSON data within TiddlyWiki HTML files
|
||||||
|
* Groups of tiddlers can be [[exported|How to export tiddlers]] and [[imported|Importing Tiddlers]] as JSON files
|
||||||
|
* Plugin tiddlers store their constituent shadow tiddlers as JSON data
|
||||||
|
* The client-server configuration uses [[JSON messages|TiddlyWeb JSON tiddler format]] to communicate between the client and the server
|
||||||
|
* Arbitrary JSON data within DataTiddlers can be processed and manipulated using a set of filter operators and action widgets
|
||||||
|
|
||||||
|
!! About JSON
|
||||||
|
|
||||||
|
The technical description of JSON at the official website https://json.org/ is terse. Here we summarise the main features.
|
||||||
|
|
||||||
|
JSON supports two basic data structures:
|
||||||
|
|
||||||
|
''Arrays'' are lists of items. The items are identified by their numeric index (starting at zero)
|
||||||
|
|
||||||
|
An example of an array is:
|
||||||
|
|
||||||
|
```json
|
||||||
|
["one","two","three\"four"]
|
||||||
|
```
|
||||||
|
|
||||||
|
Note the following features of arrays:
|
||||||
|
|
||||||
|
* The array is signified by square brackets surrounding the list of items
|
||||||
|
* Each item is a string in double quotes. Double quotes can be included within the strings by preceding them with a backslash (`\`)
|
||||||
|
* The items are separated by commas
|
||||||
|
|
||||||
|
''Objects'' are collections of name/value pairs. Each item is a value that is identified by a unique name
|
||||||
|
|
||||||
|
An example of an object is:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"first": "This is the first value",
|
||||||
|
"second": "This is the second value",
|
||||||
|
"third": "This is the third value"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Note the following features of objects:
|
||||||
|
|
||||||
|
* The object is signified by curly braces surrounding the list of name/value pairs
|
||||||
|
* Each name/value pair consists of the name in double quotes, a colon, and then the value
|
||||||
|
* The name/value pairs are separated by commas
|
||||||
|
|
||||||
|
The examples above all show string values. JSON actually supports several different types of value. Any of these types can be used as a value:
|
||||||
|
|
||||||
|
* String values, as shown above
|
||||||
|
* Numeric values, represented as signed decimals such as `1`, `3.14`. Exponential notation can also be used e.g. `-1E10`
|
||||||
|
* Boolean values, represented by the keywords `true` and `false`
|
||||||
|
* The special value `null`, which is often used to represent data that is missing or incomplete
|
||||||
|
* Objects and arrays are also values, allowing complex nested structures to be represented
|
||||||
|
|
||||||
|
!! Working with Data Tiddlers
|
||||||
|
|
||||||
|
* [[Reading data from JSON tiddlers]]
|
||||||
|
* [[Constructing JSON tiddlers]]
|
||||||
|
* [[Modifying JSON tiddlers]]
|
@ -1,6 +1,6 @@
|
|||||||
caption: format
|
caption: format
|
||||||
created: 20201020100834443
|
created: 20201020100834443
|
||||||
modified: 20210524090002126
|
modified: 20220523075550449
|
||||||
op-input: a [[selection of titles|Title Selection]]
|
op-input: a [[selection of titles|Title Selection]]
|
||||||
op-output: input strings formatted according to the specified suffix <<.place B>>
|
op-output: input strings formatted according to the specified suffix <<.place B>>
|
||||||
op-parameter: optional format string for the formats
|
op-parameter: optional format string for the formats
|
||||||
@ -21,4 +21,6 @@ The suffix <<.place B>> is one of the following supported string formats:
|
|||||||
|^`relativedate` |The input string is interpreted as a UTC date and displayed as the interval from the present instant. Any operator parameters are ignored. |
|
|^`relativedate` |The input string is interpreted as a UTC date and displayed as the interval from the present instant. Any operator parameters are ignored. |
|
||||||
|^`titlelist` |<<.from-version "5.2.0">>The input string wrapped in double square brackets if it contains a space. Appropriate for use in a [[title list|Title List]]. |
|
|^`titlelist` |<<.from-version "5.2.0">>The input string wrapped in double square brackets if it contains a space. Appropriate for use in a [[title list|Title List]]. |
|
||||||
|
|
||||||
|
<<.warning """The [[Title List]] format cannot reliably represent items that contain certain specific character sequences such as `]] `. Thus it should not be used where there is a possibility of such sequences occurring.""">>
|
||||||
|
|
||||||
<<.operator-examples "format">>
|
<<.operator-examples "format">>
|
||||||
|
@ -0,0 +1,16 @@
|
|||||||
|
title: Constructing JSON tiddlers
|
||||||
|
tags: [[JSON in TiddlyWiki]] [[Learning]]
|
||||||
|
created: 20220427174702859
|
||||||
|
modified: 20220427174702859
|
||||||
|
|
||||||
|
See [[JSON in TiddlyWiki]] for an overview of using JSON in TiddlyWiki.
|
||||||
|
|
||||||
|
JSON data is just plain text, and so there are an wide variety of techniques to generate it in wikitext.
|
||||||
|
|
||||||
|
At a high level, we have several ways to generate JSON data in TiddlyWiki's own tiddler format:
|
||||||
|
|
||||||
|
* JSONTiddlerWidget
|
||||||
|
* [[jsontiddler Macro]]
|
||||||
|
* [[jsontiddlers Macro]]
|
||||||
|
|
||||||
|
When constructing JSON data manually, the [[jsonstringify Operator]] is needed to ensure that any special characters are properly escaped.
|
18
editions/tw5.com/tiddlers/howtos/Modifying JSON tiddlers.tid
Normal file
18
editions/tw5.com/tiddlers/howtos/Modifying JSON tiddlers.tid
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
created: 20220427174702859
|
||||||
|
modified: 20220427171707459
|
||||||
|
tags: [[JSON in TiddlyWiki]] Learning
|
||||||
|
title: Modifying JSON tiddlers
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
|
See [[JSON in TiddlyWiki]] for an overview of using JSON in TiddlyWiki.
|
||||||
|
|
||||||
|
Note that
|
||||||
|
|
||||||
|
!! Using ActionSetFieldWidget and ActionListopsWidget
|
||||||
|
|
||||||
|
The widgets ActionSetFieldWidget and ActionListopsWidget can manipulate named properties of data tiddlers by indicating the name of the property in the $index attribute.
|
||||||
|
|
||||||
|
* To create or modify a named property with ActionSetFieldWidget, provide a $value attribute
|
||||||
|
* To delete a named property with ActionSetFieldWidget, omit the $value attribute.
|
||||||
|
|
||||||
|
ActionListopsWidget assigns the named property the list constructed through its $filter and $subfilter attributes.
|
@ -0,0 +1,25 @@
|
|||||||
|
created: 20220427174702859
|
||||||
|
modified: 20220427171449102
|
||||||
|
tags: [[JSON in TiddlyWiki]] Learning
|
||||||
|
title: Reading data from JSON tiddlers
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
|
See [[JSON in TiddlyWiki]] for an overview of using JSON in TiddlyWiki.
|
||||||
|
|
||||||
|
!! Text References for Accessing JSON Data
|
||||||
|
|
||||||
|
[[Text references|TextReference]] are a simple shortcut syntax to look up the value of a named property. For example, if a [[DictionaryTiddler|DictionaryTiddlers]] called `MonthDays` contains:
|
||||||
|
|
||||||
|
```
|
||||||
|
oct:31
|
||||||
|
nov:30
|
||||||
|
dec:31
|
||||||
|
```
|
||||||
|
|
||||||
|
... then `{{MonthDays##nov}}` will resolve to the value `30`.
|
||||||
|
|
||||||
|
The same is true if `MonthDays` is a [[JSONTiddler|JSONTiddlers]] with the following content:
|
||||||
|
|
||||||
|
```
|
||||||
|
{"oct":31,"nov":30,"dec":31}
|
||||||
|
```
|
@ -1,11 +1,11 @@
|
|||||||
|
caption: jsontiddlers
|
||||||
created: 20150221152226000
|
created: 20150221152226000
|
||||||
modified: 20200204135513721
|
modified: 20220427171155184
|
||||||
tags: Macros [[Core Macros]]
|
tags: Macros [[Core Macros]]
|
||||||
title: jsontiddlers Macro
|
title: jsontiddlers Macro
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
caption: jsontiddlers
|
|
||||||
|
|
||||||
The <<.def jsontiddlers>> [[macro|Macros]] returns the fields of a [[selection of tiddlers|Title Selection]] in [[JSON|JavaScript Object Notation]] form.
|
The <<.def jsontiddlers>> [[macro|Macros]] returns the fields of a [[selection of tiddlers|Title Selection]] in [[JSON|JavaScript Object Notation]] form. See [[JSON in TiddlyWiki]] for an overview.
|
||||||
|
|
||||||
An example can be seen in the [[template tiddler for JSON exports|$:/core/templates/exporters/JsonFile]].
|
An example can be seen in the [[template tiddler for JSON exports|$:/core/templates/exporters/JsonFile]].
|
||||||
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
caption: jsontiddler
|
caption: jsontiddler
|
||||||
created: 20170317140130417
|
created: 20170317140130417
|
||||||
modified: 20170317140226040
|
modified: 20220427171228844
|
||||||
tags: Macros [[Core Macros]]
|
tags: Macros [[Core Macros]]
|
||||||
title: jsontiddler Macro
|
title: jsontiddler Macro
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
The <<.def jsontiddler>> [[macro|Macros]] returns the fields of a single tiddler in [[JSON|JavaScript Object Notation]] form.
|
The <<.def jsontiddler>> [[macro|Macros]] returns the fields of a single tiddler in [[JSON|JavaScript Object Notation]] form. See [[JSON in TiddlyWiki]] for an overview.
|
||||||
|
|
||||||
!! Parameters
|
!! Parameters
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
caption: tm-new-tiddler
|
caption: tm-new-tiddler
|
||||||
created: 20140226194405353
|
created: 20140226194405353
|
||||||
modified: 20141107132122081
|
modified: 20220521143507491
|
||||||
tags: Messages navigator-message
|
tags: Messages navigator-message
|
||||||
title: WidgetMessage: tm-new-tiddler
|
title: WidgetMessage: tm-new-tiddler
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
@ -28,7 +28,7 @@ To make a button that creates new tiddlers tagged "task", create a tiddler calle
|
|||||||
<$button message="tm-new-tiddler" param="TaskTemplate">New Task</$button>
|
<$button message="tm-new-tiddler" param="TaskTemplate">New Task</$button>
|
||||||
```
|
```
|
||||||
|
|
||||||
To create a new tiddler with given attributes rather than from a template:
|
To create a new tiddler with explicit parameters rather than by cloning a template tiddler:
|
||||||
|
|
||||||
```
|
```
|
||||||
<$button>
|
<$button>
|
||||||
@ -36,3 +36,12 @@ To create a new tiddler with given attributes rather than from a template:
|
|||||||
New Tiddler
|
New Tiddler
|
||||||
</$button>
|
</$button>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
To create a new tiddler from a template with additional parameters:
|
||||||
|
|
||||||
|
```
|
||||||
|
<$button>
|
||||||
|
<$action-sendmessage $message="tm-new-tiddler" $param=<<currentTiddler>> fieldname="field value"/>
|
||||||
|
New Tiddler
|
||||||
|
</$button>
|
||||||
|
```
|
||||||
|
@ -1,14 +1,15 @@
|
|||||||
title: JSONTiddlerWidget
|
|
||||||
created: 20210630100923398
|
|
||||||
modified: 20210630100923398
|
|
||||||
tags: Widgets
|
|
||||||
caption: jsontiddler
|
caption: jsontiddler
|
||||||
|
created: 20210630100923398
|
||||||
|
modified: 20220427171128693
|
||||||
|
tags: Widgets
|
||||||
|
title: JSONTiddlerWidget
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
! Introduction
|
! Introduction
|
||||||
|
|
||||||
The jsontiddler widget renders the fields of a tiddler to display as a JSON object. The fields of the tiddler can be customised or excluded.
|
The jsontiddler widget renders the fields of a tiddler to display as a JSON object. The fields of the tiddler can be customised or excluded.
|
||||||
|
|
||||||
The jsontiddler widget is used in system templates to generate JSON representations of tiddlers for saving.
|
The jsontiddler widget is used in system templates to generate JSON representations of tiddlers for saving. See [[JSON in TiddlyWiki]] for an overview.
|
||||||
|
|
||||||
! Content and Attributes
|
! Content and Attributes
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
caption: set
|
caption: set
|
||||||
created: 20131115182700000
|
created: 20131115182700000
|
||||||
modified: 20210505095640228
|
modified: 20220523075522407
|
||||||
tags: Widgets
|
tags: Widgets
|
||||||
title: SetWidget
|
title: SetWidget
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
@ -71,6 +71,8 @@ src="""<$set name="myVariable" filter="[all[current]field:title[myMagicTitle]]"
|
|||||||
|
|
||||||
This form of the set variable widget evaluates the filter and assigns the result to the variable as a space-separated list (using double square brackets for titles containing spaces).
|
This form of the set variable widget evaluates the filter and assigns the result to the variable as a space-separated list (using double square brackets for titles containing spaces).
|
||||||
|
|
||||||
|
<<.warning """The [[Title List]] format cannot reliably represent items that contain certain specific character sequences such as `]] `. Thus it should not be used where there is a possibility of such sequences occurring.""">>
|
||||||
|
|
||||||
<<<
|
<<<
|
||||||
|
|
||||||
<$macrocall $name='wikitext-example-without-html'
|
<$macrocall $name='wikitext-example-without-html'
|
||||||
|
Loading…
Reference in New Issue
Block a user