A sample aurelia plugin based on https://github.com/Vheissu/aurelia-typescript-plugin/commit/43e863ebcd84941bb7be4894e476609f554c8f6e.
- Multiple module formats: commonjs, es2015, system and amd.
- Write plugins in TypeScript
- Definition files automatically generated using the TypeScript native compiler
- Implement testing
- Implement better linting
- Better definition generation and singular index.js export strategy
- Implement support for Wallaby.js
- Implement code coverage
src
this is where your.ts
files go. They get compiled into the respectivedist
folders for each module type.dist
automatically transpiled/generated modules go in here, don't edit anything here.styles
the root styles directory is where your styles go. These are then put into thedist
folder so your modules can include/reference any styles.
If you want your module to work appropriately with Aurelia and Webpack, ensure you define in your package.json
an Aurelia build resources map so the compiler knows where each file lives. This makes it easier for the end user consuming your package to use it without issue.
This plugin skeleton exports an AMD module format which the Aurelia CLI currently consumes.
"dependencies": [
{
"name": "sample-showtext-typescript-plugin",
"path": "../node_modules/sample-showtext-typescript-plugin/dist/amd",
"main": "index",
"resources": [
"**/*.html",
"**/*.css"
]
}
]
In main.ts of consuming project, add aurelia.use.plugin("sample-showtext-typescript-plugin")
. Add <show-text></show-text>
into one of your views.
- Clone out to local dir.
- CD into directory root
- Execute
npm link
. - CD into project that will consume plugin.
- Execute
npm link "sample-showtext-typescript-plugin"
. Add package to package.json using file: to plugin dist AMD directory. - Execute
npm install
. - Make changes in plugin source.
- Execute
npm run build
after changes in plugin project. Your changes will immediatelly be reflected at consuming project's ./node_modules/sample-showtext-typescript-plugin.