ts-import-plugin
Modular import plugin for TypeScript, compatible with antd, antd-mobile and so on.
webpack template ./webpack.config.js
, run: npm start
to see the bundle analyzer.
This plugin is not work if your are using import * as _ from 'lodash'
or import _ from 'lodash'
Why use this
transform such code:
import { Alert, Card as C } from 'antd'
into:
import Alert from 'antd/lib/alert'
import 'antd/lib/alert/style/index.less'
import { default as C } from 'antd/lib/card'
import 'antd/lib/card/style/index.less'
Usage
With ts-loader
{
...
"module": "ESNext",
...
}
const tsImportPluginFactory = require('ts-import-plugin')
module.exports = {
module: {
rules: [
{
test: /\.(jsx|tsx|js|ts)$/,
loader: 'ts-loader',
options: {
transpileOnly: true,
getCustomTransformers: () => ({
before: [ tsImportPluginFactory( ) ]
}),
compilerOptions: {
module: 'es2015'
}
},
exclude: /node_modules/
}
]
},
}
With awesome-typescript-loader ( >= 3.5.0 )
{
...
"module": "ESNext",
...
}
const tsImportPluginFactory = require('ts-import-plugin')
module.exports = {
module: {
rules: [
{
test: /\.tsx?$/,
loader: 'awesome-typescript-loader',
options: {
getCustomTransformers: () => ({
before: [ tsImportPluginFactory( ) ]
}),
},
exclude: /node_modules/
}
]
},
}
Options
options
can be an object:
-
libraryName string
default 'antd'
-
style boolean | string | ((path: string) => string)
default false
-
libraryDirectory string | ((name: string) => string)
default 'lib'
-
camel2DashComponentName boolean
default true
-
camel2UnderlineComponentName boolean
default false
-
libraryOverride boolean
default false
example:
tsImportPluginFactory({
libraryName: 'antd',
libraryDirectory: 'lib',
style: true
})
{
libraryName: '@material-ui/core',
libraryDirectory: '',
camel2DashComponentName: false
}
options
can be an array:
example:
[
{
libraryName: 'antd',
libraryDirectory: 'lib',
style: true
}, {
libraryName: '@material-ui/core',
libraryDirectory: '',
camel2DashComponentName: false
}
]
Compatible libs:
const transformerFactory = require('ts-import-plugin')
transformerFactory({ style: true })
transformerFactory({ style: 'css' })
transformerFactory()
notice you should manual import 'lodash/core'
in your project if your are using import { chain } from 'lodash'
.
transformerFactory({
style: false,
libraryName: 'lodash',
libraryDirectory: null,
camel2DashComponentName: false
})
transformerFactory({ libraryName: 'antd-mobile', style: 'css', styleExt: 'css.web' })
transformerFactory({ libraryName: 'antd-mobile', style: 'css' })
import { Button } from '@material-ui/core'
import { Remove, Refresh, Add } from '@material-ui/icons'
transformerFactory({
libraryName: '@material-ui/core',
libraryDirectory: '',
camel2DashComponentName: false
})
transformerFactory({
libraryDirectory: importName => {
const stringVec = importName.split(/([A-Z][a-z]+|[0-9]*)/)
.filter(s => s.length)
.map(s => s.toLocaleLowerCase())
return stringVec
.reduce((acc, cur, index) => {
if (index > 1) {
return acc + '-' + cur
} else if (index === 1) {
return acc + '/' + cur
}
return acc + cur
}, '')
},
libraryName: '@material-ui/icons',
style: false,
camel2DashComponentName: false
})
import { Button } from 'element-ui'
transformerFactory({
libraryName: 'element-ui',
libraryDirectory: 'lib',
camel2DashComponentName: true,
style: (path: string) =>
join('element-ui', 'lib', 'theme-chalk', `${
camel2Dash(basename(path, '.js'))}.css`),
})
see rxjs-webpack-treeshaking-example for more details
only compatible for 5.5+
transformerFactory({
libraryDirectory: '../_esm2015/operators',
libraryName: 'rxjs/operators',
style: false,
camel2DashComponentName: false,
transformToDefaultImport: false
})
transformerFactory([
{
libraryDirectory: '../_esm5/internal/operators',
libraryName: 'rxjs/operators',
camel2DashComponentName: false,
transformToDefaultImport: false
},
{
libraryDirectory: '../_esm5/internal/observable',
libraryName: 'rxjs',
camel2DashComponentName: false,
transformToDefaultImport: false,
}
])
Contributors
Code Contributors
This project exists thanks to all the people who contribute. [Contribute].
Financial Contributors
Become a financial contributor and help us sustain our community. [Contribute]
Individuals
Organizations
Support this project with your organization. Your logo will show up here with a link to your website. [Contribute]