UNPKG

@enonic-types/lib-node

Version:

Type definitions for lib-node.

64 lines (45 loc) 1.35 kB
# Enonic XP lib-node TS types > TypeScript definitions for `lib-node` library of Enonic XP ## Install ```bash npm i --save-dev @enonic-types/lib-node ``` ## Use ### Require and custom imports To make `require` work out of the box, you must install and add the `@enonic-types/global` types. Aside from providing definitions for XP global objects, e.g. `log`, `app`, `__`, etc, requiring a library by the default path will return typed object. `tsconfig.json` ```json { "compilerOptions": { "types": [ "@enonic-types/global" ] } } ``` `example.ts` ```ts const {connect, multiRepoConnect} = require('/lib/xp/node'); ``` More detailed explanation on how it works and how to type custom import function can be found [here](https://developer.enonic.com/docs/xp/stable/api). ### ES6-style import If you are planning to use `import` in your code and transpile it with the default `tsc` TypeScript compiler, you'll need to add proper types mapping to your configuration. `tsconfig.json` ```json { "compilerOptions": { "baseUrl": "./", "paths": { "/lib/xp/node": ["node_modules/@enonic-types/lib-node"] } } } ``` `example.ts` ```ts import {connect, multiRepoConnect} from '/lib/xp/node'; ``` Setting `baseUrl` and `paths` will allow the `tsc` to keep the valid paths in the resulting JavaScript files.