1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2025-01-27 09:24:45 +00:00

Add highlight plugin to /dev wiki

This commit is contained in:
Jermolene 2014-11-28 10:06:17 +00:00
parent 521e7f9b62
commit 12896ef1c4
19 changed files with 42 additions and 35 deletions

View File

@ -26,8 +26,7 @@ The scripts are designed to be executed with the current directory being the `Ti
The `package.json` in the root of the `build.jermolene.github.io` repository contains a dependency declaration that specifies the latest official released version of TiddlyWiki to be used when building the release targets:
```
```js
"dependencies": {
"tiddlywiki": "5.1.2"
}
@ -47,7 +46,7 @@ Some of the scripts use the following environment variables:
Builds the `tiddlywiki.com` target files. By default, it uses the version of tiddlywiki specified in the `package.json` file. This can be overridden with the ''TW5_BUILD_TIDDLYWIKI'' environment variable. The following command would select the latest prerelease version of tiddlywiki from the `TiddlyWiki5` directory:
```
```bash
TW5_BUILD_TIDDLYWIKI=./tiddlywiki.js
```

View File

@ -5,7 +5,7 @@ title: Data-Storage
TW has two approaches to save the user data. These approaches depends on way you use TW. either you use node.js as a server for TW its saves the tiddlers as plain text in different files or you use TW as standalone in a browser it persists the data within the HTML-File in two Div-Areas depending on whether the encryption of the TiddlyWiki is activated or not. If the TiddlyWiki is not encrypted the data is stored in the Div-Area called "~StoreArea". Every created Tiddler is stored in a own Div-area with a few custom values. An example of a saved Tiddler is shown below (\prettyref{lst:data-div}).
```
```html
<div created="20140611153703343" modified="20140611153734589" tags="testTag" testfield="testvalue" title="TestTiddler" type="text/plain">
<pre>testText</pre>
</div>

View File

@ -7,7 +7,7 @@ title: Datamodel
The micro-kernel creates a TiddlyWiki specific data-structure called tiddler. Here you have to separate the different definition of tiddlers. In the architectural view a tiddler is a JavaScript object holding some data. In the overall concept a tiddler is similar to a wiki page in a normal wiki application like wikipedia. In this section we describe the architectural view of a tiddler. The listing below shows the JSON representation of a tiddler object. During the runtime of the TiddlyWiki everything is saved an object like this. Without any plug-in the architecture is not able to persist any kind of data. All the data is stored in a store. This store is a JavaScript object. This store is constructed like a Map with a bunch of key value pairs. Every tiddler has its name as the key in the map and the JavaScript-Object as the value. The tiddler concept is the main data-model within TiddlyWiki, everything from data up to plug-ins is stored as a tiddler.
```
```javascript
{"fields":{
"text":"example Text",
"title":"Infrastruktur",

View File

@ -8,7 +8,7 @@ title: Messages
Messages are events that are triggered by the user. They are generated by widgets for example when the user clicks on a ~ButtonWidget.
Each message has a type property like "tm-delete-tiddler" and a parameter.
```
```js
{type: "tm-delete-tiddler", param: "MyOldTiddler"}
```

View File

@ -8,7 +8,7 @@ title: Module System
After the boot kernel provides the functions used to load tiddlers, the rest of the TiddlyWiki application is loaded as modules.
A module is a tiddler which has the type ``application/javascript`` and contains CommonJS compatible JavaScript code. This means a single module provides its public structures and functions in a variable called ``export``. Other modules can obtain these structures and functions by using a global ``require`` function.
```
```js
var Widget = require("$:/core/modules/widgets/widget.js").widget;
// ...
ButtonWidget.prototype = new Widget();

View File

@ -9,7 +9,7 @@ The first stage of WikiText processing is the parser.
A Parser is provided by a module with ``module-type: parser`` and is responsible to transform block of text to a parse-tree.
The parse-tree consists of nested nodes like
```
```js
{type: "element", tag: <string>, attributes: {}, children: []} - an HTML element
{type: "text", text: <string>} - a text node
{type: "entity", value: <string>} - an HTML entity like &copy; for a copyright symbol
@ -26,14 +26,15 @@ But the html-rule has another special purpose. By parsing the HTML tag syntax it
It the recognises them by the $ character at the beginning of the tag name and instead of producing "element" nodes
it uses the tag name for the type:
```
```js
{type: "list", tag: "$list", attributes: {}, children: []} - a list element
```
The [[Widgets]] part will reveal why this makes sense and how each node is transformed into a widget.
Another special characteristic of the html-rule or the parse nodes in general is the attributes property.
Attributes in the parse-tree are not stored as simple strings but they are nodes of its own to make indirect text references available as attributes as described in [[Widgets]]:
```
```js
{type: "string", value: <string>} - literal string
{type: "indirect", textReference: <textReference>} - indirect through a text reference
```

View File

@ -5,7 +5,7 @@ title: Persist data
TiddlyWiki supports a wide range of methods to persist your data. One of this methods is the HTML5 fallback saver. This methods works on almost every browser. With this method a copy of the entire wiki will be downloaded by the browser. This means you get a new file everytime you hit the save button. To avoid this and because every Browser has a different API to allow writing direct to the file system there a some plugins for the different browsers. These plug-ins allow the user to save direct to the current open TiddlyWiki-File. The Listing below shows the HTML5-compliant to save the changes via the HTML5 fallback saver by downloading the TW as a complete HTML-file.
```
```js
DownloadSaver.prototype.save = function(text,method,callback) {
...
var link = document.createElement("a");

View File

@ -17,9 +17,10 @@ This way every time a tiddler or the wiki store itself changes, each widget can
Another way of updating are text reference attributes (text references explained in [[Transclusion and TextReference]]):
```
```js
{type: "indirect", textReference: <textReference>}
```
When a widget got a attribute which is a text reference and the refresh function is called, it can check if the text reference references a changed tiddler and update accordingly.
Nearly every state of the UI is stored in tiddlers. A search mechanism for example would use a ~EditTextWidget which shows an text input field for the search string and a ListWidget to show the results.

View File

@ -7,7 +7,7 @@ title: Startup Process
Modules with ``module-type: startup`` have to export a function named ``startup`` and may export a name property to identify this module. The startup function will be executed by the boot kernel at the end of the boot process.
```
```js
// From boot.js:
// Gather up any startup modules
$tw.boot.remainingStartupModules = []; // Array of startup modules

View File

@ -27,6 +27,7 @@ Filters are noted as strings and can look like
```
[tag[task]!tag[done]interesting[very]]
```
This example would (implicitly) put all available tiddlers into the pipe.
The first operator ``tag[task]`` would only pass tiddlers which are tagged with "task".
The ``!tag[done]`` operator is negated and only passes tiddlers which are not tagged with "done".
@ -39,6 +40,7 @@ An example would be the search-operator. This filter operator looks for the sear
If the provided filter operators are not enough, a developer can add new filters by adding a module with the ``filteroperator`` type.
!!! System Tags
Tags and the filter mechanism are used throughout the core plug-in for internal puproses.
Tags which start with ``$:/`` are normally hidden from the casual user, similar to [[System Tiddlers]]

View File

@ -14,9 +14,10 @@ When a widget gets a parse node with child nodes it must create the correspondin
All this functionality is basically provided with the base widget. But when creating the widget for a parse node it loads additional modules with ``module-type: widget``. These modules can export multiple widgets which extend the base widget and can override it's methods like the rendering and refresh functions.
As described in [[Parser]] each parse node contains a "type" property. This type directly determines which widget module is used.
```
```js
{type: "text", text: <string>} - a text node
```
Would be transformed to a [[TextWidget|$:/core/modules/widgets/text.js]].
(Note that the ~TextWidget module exports a property "text".)

View File

@ -28,21 +28,21 @@ Choose a location in your file system (eg TW5) for your plugin project; issue co
!!! 1. Create the directory
```
```bash
mkdir TW5
```
!!! 2. Make a local read-only copy of the ~TiddlyWiki5 repository
```
```bash
git clone https://github.com/Jermolene/TiddlyWiki5.git TW5
```
!!! 3. Make a directory for your plugin
```
```bash
cd TW5
cd plugins
mkdir yourname
@ -53,20 +53,20 @@ mkdir pluginname
!!! 4. Make a local copy of your plugin repository
```
```bash
git clone https://github.com/yourgithub/pluginname.git pluginname
```
!!! 5. Go to your files
```
```bash
cd pluginname
```
Create the file plugin.info with content:
```
```js
{
"title": "$:/plugins/yourgithub/pluginname",
"description": "summary of the plugin's purpose",
@ -89,7 +89,7 @@ Modify `editions/tw5.com/tiddlywiki.info` to include a reference to your plugin
From the TW5 directory issue the command
```
```bash
node ./tiddlywiki.js editions/tw5.com --build index
```
@ -101,18 +101,18 @@ From `plugins/yourname/pluginname/` issue commands to:
!!! 1. Add all files
```
```bash
git add -A
```
!!! 2. Commit to your local repository
```
```bash
git commit -am "something meaningful about this check in"
```
!!! 3. Copy local changes to github
```
```bash
git push
```

View File

@ -28,7 +28,7 @@ type: text/vnd.tiddlywiki
Content of `plugin.info` for Joe Bloggs' Welsh translation:
```
```js
{
"title": "$:/languages/cy-GB",
"name": "cy-GB",

View File

@ -37,7 +37,7 @@ Click the link to the plugin tiddler to open it. Assuming it doesn't currently e
Then in the body of the tiddler, insert:
```
```js
{"tiddlers": {}}
```
@ -51,7 +51,7 @@ Create the payload tiddlers by clicking on the links in the ''HelloThere'' tiddl
Open the browser developer console, and type the following JavaScript statement, but first change the first parameter to the name of your plugin. The second parameter is an optional array of tiddler titles to be added to the plugin:
```
```js
$tw.utils.repackPlugin("$:/plugins/yourname/pluginname",["$:/plugins/yourname/pluginname/mywidget.js"])
```
@ -67,7 +67,7 @@ To test the plugin, first make sure that it has been packed. Then save changes a
Once you've built the plugin for the first time you can omit the second parameter to `repackPlugin()` unless you are adding a new tiddler:
```
```js
$tw.utils.repackPlugin("$:/plugins/yourname/pluginname")
```
@ -75,7 +75,7 @@ $tw.utils.repackPlugin("$:/plugins/yourname/pluginname")
To remove tiddlers from the plugin specify their titles in the optional third parameter:
```
```jss
$tw.utils.repackPlugin("$:/plugins/yourname/pluginname",null,["$:/plugins/yourname/pluginname/mywidget.js"])
```

View File

@ -20,7 +20,7 @@ One blank line is used to separate blocks of code. Occasional blank lines are pe
See the following example for layout of basic JavaScript constructs:
```
```js
/*
Multiline comments are used to introduce a block of code such as a function definition
*/

View File

@ -11,7 +11,7 @@ type: text/vnd.tiddlywiki
## The appropriate copy of [[node-webkit]] for your platform, downloaded from https://github.com/rogerwang/node-webkit
## Your TiddlyWiki HTML file as `index.html`
## A file called `package.json` with the following content:
##> {{packge.json for node-webkit}}
##> {{package.json for node-webkit}}
# Run the [[node-webkit]] application
#* If it doesn't work, you may need to unblock the application before your operating system will run it
#** OS X: see http://support.apple.com/kb/PH14369

View File

@ -9,7 +9,7 @@ title: TiddlyWiki5 Development Environment
[[Installing TiddlyWiki5]] with NPM downloads a snapshot release of TiddlyWIki5. To use a development copy of the TiddlyWiki5 repository instead of the copy installed by [[NPM]], use this command within the root of the TiddlyWiki5 repo:
```
```bash
npm link
```
@ -17,7 +17,7 @@ npm link
As releases are made during development it is necessary to adjust the version number of the TiddlyWiki5 core. This is done with the [[npm version|https://npmjs.org/doc/version.html]] command. For example:
```
```bash
npm version 5.0.0-alpha.10
```

View File

@ -5,7 +5,9 @@ type: text/vnd.tiddlywiki
The hook mechanism provides a way for plugins to intercept and modify default functionality. Hooks are added as follows:
``$tw.hooks.addHook(name,handler);``
```js
$tw.hooks.addHook(name,handler);
```
Multiple handlers can be assigned to the same name using repeated calls. When a hook is invoked by name all registered functions will be called sequentially in their order of addition.
@ -15,7 +17,7 @@ Though not essential care should be taken to ensure that hooks are added before
A working example of a hook that adds "test" to the default tiddlers.
```javascript
```js
$tw.hooks.addHook("th-opening-default-tiddlers-list",function(list) {
list.push("test");
return list;

View File

@ -1,6 +1,7 @@
{
"description": "Developer documentation from http://tiddlywiki.com/dev/",
"plugins": [
"tiddlywiki/highlight",
"tiddlywiki/cecily",
"tiddlywiki/googleanalytics",
"tiddlywiki/nodewebkitsaver",