nkd-factory
Version:
JavaScript base factory
138 lines (103 loc) ⢠3.32 kB
Markdown
# nkd-factory
š¦ JavaScript bundler/linter
---
### Usage
```bash
yarn add nkd-factory --dev
```
**package.json**
```json
"scripts": {
"build": "nkd build",
"lint": "nkd lint --ext .ts,.kdu src"
}
```
```bash
yarn build
```
---
### Config
Create `nkd.config.js` in project root. More detail is [here](https://github.com/khanhduy1407/nkd-factory/blob/master/lib/default.js).
`nkd.config.js` type: `NkdConfigObject | NkdConfigObject[] | (defaultRollupConfig) => RollupConfog`.
**config object**
```ts
// nkd.config.js
module.exports = {
// entry file, default: 'src/index.js'
entry?: string
// lib name, default: auto get by package.json.name, like: 'KduAwesomeSwiper'
name?: string
// out file name, default: auto get by package.json.name, like: 'kdu-awesome-swiper'
fileName?: string
// output dir, default: 'dist'
outDir?: string
// output bundle types, default: ['umd', 'esm', 'cjs']
targets?: string[]
// exports moudle type, default: 'auto'
exports?: string
// @rollup/plugin-replace config, default { PACKAGE_VERSION, 'process.env.NODE_ENV' }
replace?: object
// parser type, default: 'buble', options: 'buble' | 'babel'
parser?: string
// parser plugin options, default rollup-plugin-buble options
parserOptions?: object // {}
// todo file formats, default: ['.mjs', '.js', '.jsx', '.json', '.ts']
resolve?: string[]
// enable kdu plugin, default: auto get by package.json.<xxx>dependencies
kdu?: false | { /* rollup-plugin-kdu config */ }
// enable eslint plugin (before build), default: false
eslint?: false | { /* rollup-plugin-eslint config */ }
// enable typescript plugin (before build), default: auto get by package.json.dependencies
typescript?: false | { /* rollup-plugin-typescript2 config */ }
// compression
minimize?: boolean // true
// file header
banner?: string // default: https://github.com/khanhduy1407/nkd-factory/blob/master/lib/default.js#L18
// Refer to https://rollupjs.org/guide/en/#warning-treating-module-as-external-dependency
// list external dependencies, exactly the way it is written in the import statement.
external?: string[]
// Refer to https://rollupjs.org/guide/en#output-globals for details
// Provide global variable names to replace your external imports
globals?: {
[key: string]: string
}
}
```
**config function**
```ts
// nkd.config.js
module.exports = (defaultRollupConfig): RollupConfog => {
// overwrite the default Rollup confog
// ...
return RollupConfig
}
```
---
### Preset (about nkd provide preset configs)
**[tsconfig.json - extends](https://www.typescriptlang.org/tsconfig#extends)**
```js
{
"extends": "./node_modules/nkd-factory/preset/tsconfig/kdu",
// your options like:
"compilerOptions": {
"declaration": true,
"declarationDir": "types",
"baseUrl": ".",
// ...
},
"exclude": [
"node_modules",
"dist",
// ...
]
}
```
**[.eslintrc.js extends](https://eslint.org/docs/user-guide/configuring#extending-configuration-files)**
```js
module.exports = {
extends: './node_modules/nkd-factory/preset/eslintrc/kdu.typescript',
rules: {
// rules...
}
}
```