vite-versioner-utility-plugin
v2024.2.17
Published
This project includes: - [TypeScript](https://www.typescriptlang.org/) - [Rollup](https://rollupjs.org/) - [Microsoft API Extractor](https://api-extractor.com/) - [TypeDoc](https://typedoc.org/)
Readme
Vite Versioner Utility Plugin
This project includes:
Usage
The following tasks are available for npm run:
dev: Run Rollup in watch mode to detect changes to files during developmentbuild: Run Rollup to build a production release distributablebuild:types: Run Microsoft API Extractor to rollup a types declaration (d.ts) filedocs: Run TypeDoc for TSDoc generated documentation in the "docs/" folderclean: Remove all build artifactsproduction: Remove all build artifacts, build, build types, publish to npm (if logged in)
Development
While test driven development (TDD) would be a good approach to develop your library, also consider creating an app for prototyping and local testing of your library.
To test within the library, consider using Storybook. This approach runs a storybook script to load local source files for development.
Otherwise, follow these steps to test the package from another project:
From your library project, issue the npm link (or yarn link) command:
npm linkStart Rollup in watch mode:
npm run devCreate a test app project, by doing the following:
To use your npm package library locally for development, create a new project in a separate folder:
mkdir test-app && cd test-app
npm initTake the defaults from npm init; then, add TypeScript:
npm install typescript --save-devIn the package.json of your test app, add the following two things:
- Set the
typeof your package tomodule - Add a
startscript to execute your app
"type": "module",
"scripts": {
"start": "tsc && node index.js",
},Link to your library using the npm link <name> (or yarn link <name>) command - be sure the <name> matches your library's package.json name. For example:
npm link vite-versioner-utility-pluginAdd a "tsconfig.json" file to your test app that includes a baseUrl and references the paths to your npm linked module. Again, be sure the paths name matches your library's package.json name. For example:
{
"compilerOptions": {
"target": "es6",
"module": "esnext",
"moduleResolution": "node",
"strict": true,
"esModuleInterop": true,
"baseUrl": ".",
"paths": {
"vite-versioner-utility-plugin": ["node_modules/vite-versioner-utility-plugin/src"],
"vite-versioner-utility-plugin/*": ["node_modules/vite-versioner-utility-plugin/src/*"]
}
}
}Now, run your app via npm start.
The test app implements an import using the package name, such as:
import { versionerUtility } from "vite-versioner-utility-plugin";
versionerUtility();Development Cleanup
Once development completes, unlink both your library and test app projects.
From your test app project, unlink the library using npm unlink <name> (or yarn unlink <name>) command:
npm unlink vite-versioner-utility-pluginFrom your library project, issue the npm unlink (or yarn unlink) command:
npm unlinkRelease Publishing
Update your package.json to next version number, and remember to tag a release.
Once ready to submit your package to the NPM Registry, execute the following tasks via npm (or yarn):
npm run clean— Assure a clean buildnpm run build— Build the packagenpm run build:types— Build API Extractor d.ts declaration
Assure the proper npm login:
npm loginSubmit your package to the registry:
npm publish --access public