TypeScript type definitions for TiddlyWiki5.
Doc Site - tiddly-gittly.github.io/TW5-Typed
First, install it as dev-dependency:
npm i -D tw5-typed
Add tw5-typed
to your tsconfig.json
's compilerOptions
{
"compilerOptions": {
"types": ["node", "tw5-typed"] /* Type declaration files to be included in compilation. */
}
}
Then you will have global types like $tw
automatically. You can import the rest of the types using import type
statement:
import type { ISearchOptions, SourceIterator, IFilterOperatorParamOperator } from 'tiddlywiki';
Sometimes you may want to use a modified version of tw, you can re-export types like this in your src/type.d.ts
:
declare module '@tiddlygit/tiddlywiki' {
export * from 'tiddlywiki';
}
Firstly, Install eslint using npm:
npm i
You can add new *.d.ts
file to contain your types:
- use
declare module 'tiddlywiki' { }
to wrap all your types. - don't forget to
export
all your types. - to add type for global variable, add
global { }
inside thatdeclare module 'tiddlywiki' { }
, likeglobal { var $tw: I$TW; }
- add type import like
/// <reference path="ast.d.ts" />
in thetw.d.ts
- add type import like
/// <reference path="parser.d.ts" />
- using normal import, like
import { parse } from './parser';
will not work
To rapid prototype the type, just right click a type to open .d.ts
file in the node_modules
, and try create new file there, and copy to this repo after a success.
Make sure doc build and test are passed.
- Doc:
pnpm run docs:generate && pnpm run docs:dev
, see.github\workflows\deploy-docs-to-github-pages.yml
- Tests:
pnpm run check
, see.github\workflows\test.yml