Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tiddly-gittly/zx-script
Run Javascript inside tiddlywiki like jupyter notebook
https://github.com/tiddly-gittly/zx-script
code-execution interactive ipython-notebook javascript jupyter-notebook literate-programming neteract playground tiddlywiki tiddlywiki5 tidgi zx
Last synced: about 1 month ago
JSON representation
Run Javascript inside tiddlywiki like jupyter notebook
- Host: GitHub
- URL: https://github.com/tiddly-gittly/zx-script
- Owner: tiddly-gittly
- License: mit
- Created: 2023-06-08T13:31:43.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-12-07T15:04:18.000Z (about 1 month ago)
- Last Synced: 2024-12-07T16:17:58.349Z (about 1 month ago)
- Topics: code-execution, interactive, ipython-notebook, javascript, jupyter-notebook, literate-programming, neteract, playground, tiddlywiki, tiddlywiki5, tidgi, zx
- Language: TypeScript
- Homepage: https://tiddly-gittly.github.io/zx-script/
- Size: 1.46 MB
- Stars: 3
- Watchers: 0
- Forks: 0
- Open Issues: 12
-
Metadata Files:
- Readme: readme.tid
- License: LICENSE
Awesome Lists containing this project
README
title: $:/plugins/linonetwo/zx-script/readme
!! Background
[[google/zx|https://github.com/google/zx]] is a tool for writing better scripts, with Javascript.
This tiddlywiki plugin enables you to run any tiddler with zx.
!! Prerequisit
This plugin requires [[TidGi Desktop App|https://github.com/tiddly-gittly/TidGi-Desktop]] environment to function properly. It will send tiddler content to the `zx` inside TidGi, and prints the output.
!! Basic Usage
!!! Button
A ViewToolbar button is added. You can click on it to execute the script inside your tiddler.
And the zx output will be printed below your tiddler content.
Tiddler with title extension `*.js *.md *.mjs` can be execute without problem. Other tiddler witout extension (no `.xxx`) will be executed as `*.md` file, for example, tid file without extions will be executed as `*.md`, but it works without problem too, even you are writing wiki text instead of markdown.
If you add filetype `application/javascript` to your tiddler, it will be recognized as `*.mjs`.
!!! Codeblock
An execution button is added to the codeblock widget, if language is supported.
```js
console.log(`!! Hi!`);
```See [[$:/plugins/linonetwo/zx-script/demo]] for demo of full tiddler execution.
!! Wiki Scripting
!!! Execute the code block on the $tw context
You can write some code that is surrounded with `/** tw */` separator. They will be recognized as js code and executed on the context that have access to the $tw api.
See [[$:/plugins/linonetwo/zx-script/demo]] for examples.
Global variables you can use:
* `$tw` try it in your [[developer tool|https://developer.mozilla.org/en-US/docs/Tools]] to play around!
* `_` [[lodash|https://lodash.com/docs/]]This means you can fetch some data on the zx script, and write the results to the wiki, creating new tiddlers.
!!! Access filter and macros
Filter function's call example is
```js
/** tw */
const result = $tw.wiki.filterOperators.sum((callback) => {callback({}, '2');callback({}, '2')})
console.log(result)
```!! Developer Documentation
See [[$:/plugins/linonetwo/zx-script/developer]]