JSPM

@ogs-gmbh/rolldown-plugin-package-json

1.1.0
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 58
  • Score
    100M100P100Q84177F
  • License MIT

A powerful and flexible plugin for Rolldown that enhances package.json handling.

Package Exports

  • @ogs-gmbh/rolldown-plugin-package-json

Readme

We're OGS, check out our work on github.com/ogs-gmbh

package.json Plugin for Rolldown

A powerful and flexible plugin for Rolldown that enhances package.json handling.

Preview

license badge workflow badge npm badge

  • Package Transformation
    Automated copying and modification of package.json, allowing selective removal of fields to produce a clean, production-ready manifest.

  • Dynamic Exports Generation
    Automatically generates exports maps based on build outputs, ensuring correct module resolution for ESM and CommonJS environments.

  • Dependency Optimization
    Integrates with the build pipeline to control dependency handling and reduce unnecessary bundle inclusion.

  • Build-Time Integration
    Seamlessly hooks into the Rolldown lifecycle to perform transformations efficiently during the build process.

Getting Started

[!IMPORTANT] We're offering an extensive API-Reference covered with in-depth usage examples of this project.

To get a starting point, simply refer to our documentation at ogs-gmbh.github.io/rolldown-plugin-package-json.

Prerequisites

  • Node.js version 18 or higher
  • A package manager: e.g. npm, pnpm, ...

Installation

Using npm:

$ npm add -D @ogs-gmbh/rolldown-plugin-package-json
Using a different package manager?

Using yarn:

$ pnpm add -D @ogs-gmbh/rolldown-plugin-package-json

Using pnpm:

$ pnpm add -D @ogs-gmbh/rolldown-plugin-package-json

Using bun:

$ bun add -D @ogs-gmbh/rolldown-plugin-package-json

Usage

rolldown-plugin-package-json can be integrated with either tsdown or Rolldown. Here's an example showing the usage of this plugin with tsdown. You can get a deeper understanding about this plugin by taking a look into the reference.

import { defineConfig } from "tsdown";
import { packageJsonPlugin } from "@ogs-gmbh/rolldown-plugin-package-json";

export default defineConfig({
  entry: "src/**/*.ts",
  dts: true,
  outDir: "dist/main",
  unbundle: true,
  plugins: [
    packageJsonPlugin({
      clean: true,
      exports: {
        enabled: true,
        override: { ".": "./public-api.mjs", "./feature-a": "feature-a.mjs" }
      }
    })
  ]
});

License

The MIT License (MIT) - Please have a look at the LICENSE file for more details.

Contributing

Contributions are always welcome and greatly appreciated. Whether you want to report a bug, suggest a new feature, or improve the documentation, your input helps make the project better for everyone.

Feel free to submit a pull request, issue or feature request.

Issues and Feature Requests

Reporting an issue or creating a feature request is made by creating a new issue on this repository.

You can create a new issue or feature request here.

Pull Requests

GitHub offers a solid guideline for contributing to open source projects through pull requests, covering key practices. These best practices provide a reliable starting point for making effective contributions.

You can find the guidelines here.

Code Of Conduct

We are committed to keeping a welcoming, inclusive, and respectful community for everyone. To help us achieve this, we kindly ask that you adhere to our Code of Conduct.

Disclaimer

All trademarks and registered trademarks mentioned are property of their respective owners and are used for identification purposes only. Use of these names does not imply endorsement or affiliation.

This project is a trademark of OGS Gesellschaft für Datenverarbeitung und Systemberatung mbH. The License does not grant rights to use the trademark without permission.


OGS Logo

Gesellschaft für Datenverarbeitung und Systemberatung mbH

Imprint | Contact | Careers