Creating a new extension

Once you have created the IrisX App, you will need to create an extension and connect it to the app. An extension is either a hook in to a certain place in the Manager UI or a report.

1. Create your first extension

npx nx g @trackunit/iris-app:extend [name-of-your-extension]

2. Answer the following questions:

  • What subdir would you like to use for this app-extension?:

    • Trackunit recommends bundling extensions as related yet independent components of larger features. You can decide to leave this field empty, and then your extension's folder will be created in the root. If you do so, ensure to give your extension a unique name in order to prevent any conflicts. But if you are working on bigger things, you have the option to put extensions in the same subfolder. It will not impact functionality, but it helps structuring your code.
  • What app should this app-extension extend?:

    • Enter the app name used in step 3 in the Creating a new app section (e.g., my-first-app).
      • ๐Ÿ“Œ This question will not appear if you only have a single app in your NX Workspace.
  • Which IrisX App extension should be generated?:

โœ” What name would you like to use for this app-extension? ยท [name-of-your-extension]
โœ” What subdir would you like to use for this app-extension? ยท [feature-name]
โœ” Which IrisX App extension should be generated? ยท FLEET_EXTENSION

CREATE libs/[feature-name]/[name-of-your-extension]/extension-manifest.ts
UPDATE package.json
UPDATE nx.json
CREATE jest.config.ts
CREATE jest.preset.js
UPDATE .vscode/extensions.json
CREATE babel.config.json
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/project.json
CREATE .eslintrc.json
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/.eslintrc.json
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/.babelrc
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/README.md
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/tsconfig.json
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/tsconfig.lib.json
UPDATE tsconfig.base.json
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/jest.config.ts
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/tsconfig.spec.json
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/src/app.spec.tsx
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/src/app.tsx
CREATE libs/[subdir-of-your-extension]/[name-of-your-extension]/src/index.tsx

3. After answering all the questions, a new extension will be created under the libs folder.

โŠข libs
	โŠข [subdir-of-your-extension]/[name-of-your-extension]
      โŠข src
        โŠข app.tsx
        โŠข index.ts
      โŠข .babelrc
      โŠข .eslintrc.json
      โŠข extension-manifest.ts
      โŠข jest.config.js
      โŠข project.json
      โŠข README.md
      โŠข tsconfig.json
      โŠข tsconfig.lib.json
      โŠข tsconfig.spec.json
    โŠข .gitkeep

4. The new extension is also added to the iris-app-manifest.ts file in your IrisX App under apps.

  extensions: [[name-of-your-extension]Extension],

Example of an Extension Manifest

(in this example a Report extension)

import { ReportExtensionManifest } from "@trackunit/iris-app-api";

const extensionManifest: ReportExtensionManifest = {
  id: "your-report-id-extension",
  type: "REPORT_EXTENSION",
  main: "<path-to-report-in-jasper>",
};

export default extensionManifest;

Now that you have created an IrisX App with 1 extension, you are ready to run the IrisX App.
( you can add more extensions or new IrisX Apps later )