JSPM

  • Created
  • Published
  • Downloads 253
  • Score
    100M100P100Q106789F
  • License Apache-2.0

Tools for managing Projen configuration automation within a Nx workspace.

Package Exports

  • @storm-software/projen
  • @storm-software/projen/components
  • @storm-software/projen/components/index
  • @storm-software/projen/components/nx-workspace
  • @storm-software/projen/docs/api/generators/init/schema.md
  • @storm-software/projen/executors
  • @storm-software/projen/generators
  • @storm-software/projen/generators.json
  • @storm-software/projen/generators/init/generators.js
  • @storm-software/projen/generators/init/schema.json
  • @storm-software/projen/index
  • @storm-software/projen/package.json

Readme

Storm Software


This package is part of the ⚡Storm-Ops monorepo. The Storm-Ops packages include CLI utility applications, tools, and various libraries used to create modern, scalable web applications.

💻 Visit stormsoftware.com to stay up to date with this developer


Version Nx NextJs Commitizen friendly Semantic-Release documented with Fumadocs GitHub Workflow Status (with event)

[!IMPORTANT] This repository, and the apps, libraries, and tools contained within, is still in it's initial development phase. As a result, bugs and issues are expected with it's usage. When the main development phase completes, a proper release will be performed, the packages will be available through NPM (and other distributions), and this message will be removed. However, in the meantime, please feel free to report any issues you may come across.

Be sure to ⭐ this repository on GitHub so you can keep up to date on any daily progress!

Table of Contents


Storm Projen Tools

A package containing tools and base classes for the Projen configuration management package to be used in a Storm workspace. It includes various Nx generators and executors for common development tasks.

This library was generated with Nx.

Installing

Using pnpm:

pnpm add -D @storm-software/projen
Using npm
npm install -D @storm-software/projen
Using yarn
yarn add -D @storm-software/projen

Executors

The following executors are available in this package to invoke common tasks for the workspace's projects:

helm-package

Package Helm charts associated with a project

Example

This executor can be used by executing the following in a command line utility:

nx run my-project:helm-package

Please note: The helm-package executor should be included in the desired projects's project.json file.

container-publish

Deploy an OCI Image Format Specification to a container registry

Example

This executor can be used by executing the following in a command line utility:

nx run my-project:container-publish

Please note: The container-publish executor should be included in the desired projects's project.json file.

Generators

The following generators are available with this package to assist in workspace management:

Init Generator

A type definition for the Projen init generator schema

Options

The following executor options are available:

Option Type Description Default
directory string The directory to initialize the workspace in
skipFormat boolean Skip formatting the generated files

Building

Run nx build projen to build the library.

Running unit tests

Run nx test projen to execute the unit tests via Jest.

Storm Workspaces

Storm workspaces are built using Nx, a set of extensible dev tools for monorepos, which helps you develop like Google, Facebook, and Microsoft. Building on top of Nx, the Open System provides a set of tools and patterns that help you scale your monorepo to many teams while keeping the codebase maintainable.


Roadmap

See the open issues for a list of proposed features (and known issues).


Support

Reach out to the maintainer at one of the following places:


License

This project is licensed under the Apache License 2.0. Feel free to edit and distribute this template as you like.

See LICENSE for more information.


Changelog

This project adheres to Semantic Versioning. Every release, along with the migration instructions, is documented in the CHANGELOG file


Contributing

First off, thanks for taking the time to contribute! Contributions are what makes the open-source community such an amazing place to learn, inspire, and create. Any contributions you make will benefit everybody else and are greatly appreciated.

Please try to create bug reports that are:

  • Reproducible. Include steps to reproduce the problem.
  • Specific. Include as much detail as possible: which version, what environment, etc.
  • Unique. Do not duplicate existing opened issues.
  • Scoped to a Single Bug. One bug per report.

Please adhere to this project's code of conduct.

You can use markdownlint-cli to check for common markdown style inconsistency.


Contributors

Thanks goes to these wonderful people (emoji key):

Patrick Sullivan
Patrick Sullivan

🎨 💻 🔧 📖 ⚠️
Tyler Benning
Tyler Benning

🎨
Stormie
Stormie

🚧
All Contributors Add your contributions

This project follows the all-contributors specification. Contributions of any kind welcome!




Storm Software

Fingerprint: F47F 1853 BCAD DE9B 42C8 6316 9FDE EC95 47FE D106

Storm Software is an open source software development organization and creator of Acidic, StormStack and StormCloud.

Our mission is to make software development more accessible. Our ideal future is one where anyone can create software without years of prior development experience serving as a barrier to entry. We hope to achieve this via LLMs, Generative AI, and intuitive, high-level data modeling/programming languages.

Join us on Discord to chat with the team, receive release notifications, ask questions, and get involved.

If this sounds interesting, and you would like to help us in creating the next generation of development tools, please reach out on our website or join our Slack channel!


Storm Software

Visit us at stormsoftware.com