3.2.1 • Published 5 months ago

@resolution/reforge v3.2.1

Weekly downloads
-
License
MIT
Repository
bitbucket
Last release
5 months ago

Reforge ⚒️🔥

https://www.npmjs.com/package/@resolution/reforge https://www.npmjs.com/package/@resolution/reforge https://bitbucket.org/resolutiongmbh/reforge version

A project of:

https://resolution.de

Atlassian apps that get it done

What is Reforge?

Reforge is an opinionated bundler for forge projects that uses esbuild to easily generate your distribution files from a developer-friendly project structure.

How to use Reforge?

  1. In your project add the reforge dependency: npm i @resolution/reforge, yarn add @resolution/reforge, pnpm add @resolution/reforge, etc.

  2. Copy the following folder structure (in the future you'll be able to do forge create):

    .
    ├── src/                          -- Source files
    │   ├── modules/                  -- Module entries
    │   │   ├── jira$globalPage/      -- A jira:globalPage module
    │   │   │   └── application.tsx   -- A jira:globalPage entry
    │   │   └── function/             -- A function module
    │   │       └── backend.ts        -- A function entry
    │   └── app.ts                    -- Configuration file (optional)
    ├── assets/                       -- Asset files (optional)
    │   └── image.jpg                 -- An asset file to copy into the resource directory of resources that reference it (optional)
    ├── .env                          -- Declare your app id here (required)
    └── package.json
  • Application file (app.ts) may export ^1: default: The base manifest. This is the place to define non-module options like permissions, or additional modules that can just be copied without being processed. Any resources you pass will be copied and rewritten into the dist directory. reforgeConfig: Optional config for Reforge, see more here.

  • Resource entrypoints (e.g jira$globalPage.tsx) may export: default (required): A React component that will be passed to react-dom to be rendered when the entrypoint is accessed. reforgeResourceAssets: A string[] containing the filenames of assets from the assets directory to copy into this resource's directory. These are typically images, JSON files, etc.

  • Any module entrypoints (e.g backend.ts) may export ^1: reforgeModuleManifest: The section of the manifest to generate for this file. For resources, this will typically contain things like a title, icon etc. May instead export as a function (optionally async) that takes a Record<string, string> with the environment based on the environment variables from the .env files, as well as NODE_ENV (build mode, either production or development).

^1: Non-resource entrypoints may instead be exported as a function (optionally async) that takes a Record<string, string> with the environment based on the environment variables from the .env files, as well as NODE_ENV (build mode, either production or development).

  1. Call reforge build with: npx reforge build, yarn reforge build, pnpm reforge build, etc.

    • Optional: Add the previous command to your scripts section in the package.json.
  2. A dist/ folder that is ready to be deployed will be generated.

    • Optional: cd into distand run forge deploy and forge install.
    • Optional: add the previous command to your scriptssection in the package.json.

Why should you use Reforge?

FeaturesReforgeForge
bundles codeyesno
languagetypescriptany
frameworkreactany
manifestautomaticmanual

Roadmap

DescriptionVersionReleased
Initial release, reforge bundler1.0.0yes
Improved dev mode, asset directory support1.1.0yes
Rewrite to ESBuild, better configurability2.0.0yes
DOMException polyfill2.0.1yes
Downgrade peer react version2.1.0yes
Add support for custom renderers2.2.0yes
Create command for projects and modules?.?.?no
Proper ESM distribution files?.?.?yes
Backend-frontend type inference ^4?.?.?no
Product API type inference?.?.?no
Write proper documentation?.?.?no

^4: Meanwhile, check forge-trpc

3.2.2-rc3

5 months ago

3.2.2-rc1

5 months ago

3.2.2-rc2

5 months ago

3.2.1

7 months ago

3.2.0

7 months ago

3.1.3

9 months ago

3.1.2

10 months ago

3.1.1

11 months ago

3.1.0

11 months ago

3.1.6

8 months ago

3.1.5

8 months ago

3.1.4

8 months ago

3.2.0-rc.1

7 months ago

3.0.1

12 months ago

3.0.0-rc7

1 year ago

3.0.0-rc6

1 year ago

3.0.0-rc5

1 year ago

3.0.0-rc4

1 year ago

3.0.0-rc3

1 year ago

3.0.0-rc2

2 years ago

3.0.0-rc1

2 years ago

2.2.3-rc3

2 years ago

2.2.3

2 years ago

2.2.3-rc1

2 years ago

2.2.3-rc2

2 years ago

2.2.2-rc6

2 years ago

2.2.2-rc4

2 years ago

2.2.2-rc5

2 years ago

2.2.2-rc2

2 years ago

2.2.1

2 years ago

2.2.2-rc3

2 years ago

2.2.0

2 years ago

2.2.2

2 years ago

2.2.2-rc1

2 years ago

2.1.0

2 years ago

2.2.1-rc2

2 years ago

2.2.1-rc1

2 years ago

2.2.0-rc3

2 years ago

2.2.0-rc2

2 years ago

3.0.0-alpha1

2 years ago

2.2.0-a

2 years ago

2.0.2-rc1

3 years ago

1.1.0

3 years ago

2.0.3-rc1

3 years ago

2.0.2

3 years ago

2.0.1

3 years ago

2.0.0

3 years ago

1.0.0-j

3 years ago

1.0.0-i

3 years ago

1.0.0-h

3 years ago

1.0.0-g

3 years ago

1.0.0-f

3 years ago

1.0.0-e

3 years ago

1.0.0-d

3 years ago

1.0.0-c

3 years ago

1.0.0-b

3 years ago

1.0.0-a

3 years ago

1.0.0

3 years ago