just a minor question regarding ForgeUI. I’m not very familiar with React/Forge as Backend Dev so this might be hopefully easy to solve for you. ^^
I’m using IntelliJ IDEA and frequently use ‘reformat code’ to optimize imports automatically and format code. This is also invoked when any code is committed.
But the automatic organize import keeps removing ForgeUI when I use:
Could it be an Optimize Imports feature? Please try turning it off and see whether it works for you? If it works, at may be worth exploring how to ignore some imports in IntelliJ if you really need that feature.
Hey @vpetrychuk, thanks for following up!
Yes exactly it’s reformat code + organize imports. This is standard to keep things organized and we enable it before any commit to do this automatically. Moreover, with the shortcut, I do this all the time during development.
Actually, I added a noinspection instruction on top and now it works fine, although not perfect since now unused imports are not removed automatically anymore. But at least they are still automatically ordered.
Example
Unfortunately, I do not know how to make IntelliJ ignore ForgeUI import. Many projects resolve this issue in a different way - they switch to eslint + prettier to enforce formatting and additional rules for everyone, no matter what IDE they use. With a precommit hook (and CI/CD) these two tools would make sure everyone formats the code before it is pushed to remote.
I’m not entirely happy with this solution but it kinda worked for me in the past so sharing it here:
import ForgeUI, { useConfig } from "@forge/ui";
import { pleaseDoNotOptimizeTheseUnusedImports } from "./utils";
pleaseDoNotOptimizeTheseUnusedImports(ForgeUI)
while the utils.js looks like this:
export const pleaseDoNotOptimizeTheseUnusedImports = function (...args) {
// Requirement: The ForgeUI import must happen for UI-kit based modules to work
// Problem: The "organize imports" operation will automatically get rid of ForgeUI import as it's not used
// Solution: dummy pleaseDoNotOptimizeThisUnusedImport(ForgeUI) makes everyone happy...
return args;
}
This stops IntelliJ from optimizing import as it’s used now, while that usage is not doing anything useful.
I prefer this over the noinspection but that’s personal preference.
Yes, it would be enough - that would disable the import optimization. But then you also need the // noinspection BadExpressionStatementJS on top of this line as it will be triggering the Expression statement is not assignment or call warning. I know that those comments can move around easily so I prefer the dummy function call instead, but as I said I’m not 100% happy with this workaround (it works but it ain’t pretty).
Side note: AFAIR IntelliJ IDEA somehow does not warn us about the unused React import (import React from "react";) so probably there is some other way to make it ignore ForgeUI. But I wouldn’t be too surprised if that’s hardcoded somewhere deep into React support for IDEA.
I think this is related to the file extension (JSX or TSX) as it detects that the import of React is required given that JSX/TSX will be translated to React.createElement().
We were having the same problem with ForgeUI being removed by IntelliJ and reported by Eslint Typescript plugin as an ununsed-var.
The solution was to add this to our tsconfig.json under compilerOptions