TypeScript troubleshooting
Nutrient Web SDK ships with a TypeScript declaration file(opens in a new tab) for first-level support of TypeScript projects.
Ideally, when compiling your TypeScript project, everything should work without issues. However, in some cases you might observe errors pointing to Nutrient Web SDK, such as the following error that occurs during compilation time (i.e. when tsc runs):
ERROR in node_modules/pspdfkit/dist/index.d.ts:4906:31 - error TS1005: ',' expected.
4906 declare type InsetJSON = [left: number, top: number, right: number, bottom: number];                                   ~The error shown above might look different for you; it’s merely a reference to the general output thrown by TypeScript that might appear when integrating Nutrient Web SDK into your project.
This happens because our TypeScript declaration file relies on a newer version of TypeScript than the one you’re currently using. Try one of the approaches outlined below to solve this specific issue.
Upgrading your TypeScript version
If possible for your specific project, upgrading your TypeScript version to the most recent one should fix the issue.
If instead, you’d like to upgrade to the minimum necessary version of TypeScript that correctly parses the Nutrient declaration file, look for the specific TypeScript error code that you’re observing (e.g. TS1005), and search the internet to find the TypeScript release that shipped with that change.
Unfortunately, it isn’t trivial to update TypeScript versions for some projects. We’ve seen this being the case for teams relying on older versions of the Angular framework. In these cases, you can try one of the following approaches.
Patching the declaration file Nutrient ships with
In most cases, there are only a few bits of conflicting syntax between the Nutrient declarations and your TypeScript version. For these cases, you can manually adapt our declarations as needed and mostly keep all the benefits of the type declarations.
Using patch-package (recommended approach)
patch-package(opens in a new tab) is a tool for performing manual changes to npm dependencies while allowing you to apply regular updates to the underlying dependencies. In this case, you can use it to change the type declarations shipped by Nutrient.
- Go to the location of the .d.tsfile in your Nutrient installation (usuallynode_modules/pspdfkit/dist/index.d.ts).
- Perform the necessary changes to the file so that it’s compatible with your TypeScript version.
For instance, take our example from above:
declare type InsetJSON = [  left: number,  top: number,  right: number,  bottom: number];It relies on a feature called labeled tuple elements(opens in a new tab), which were introduced in TypeScript 4.0. An alternative for earlier TypeScript versions is to drop the labels:
declare type InsetJSON = [number, number, number, number];- Follow the setup instructions(opens in a new tab) for patch-package.
- Run npx patch-package pspdfkit.
- Use Git to add the patch generated by patch-packageand commit the changes:
git add patches/pspdfkit+2022.1.2.patchgit commit -m "fix type declarations in PSPDFKit"Resolving types for Nutrient to a different path
If using patch-package isn’t feasible, you can replace the declaration file from Nutrient Web SDK with a different one. Here’s how you can copy the original index.d.ts file that Nutrient ships with and modify it to adapt it to the current version that you’re shipping with.
- Copy the declaration file from Nutrient to a location in your project: - Terminal window $ cp node_modules/pspdfkit/dist/index.d.ts src/pspdfkit.d.ts
- Apply the fix necessary. 
- Modify your - tsconfig.jsonfile with something like the following:
{  "compilerOptions": {    "baseUrl": "./",    "paths": {      "pspdfkit": ["src/pspdfkit.d.ts"]    }  }}Replace src/pspdfkit.d.ts with the location of your modified copy of the Nutrient declaration type.
Check the TypeScript handbook(opens in a new tab) for more information about the paths setting.
Please note that this approach might provoke some issues later on when you update the version of Nutrient Web SDK, since types might have changed since the current one and your declaration files might reflect incorrect values. For this reason, after each Nutrient update in your project, be sure to include the changes to the declaration file that the new Nutrient Web SDK version ships with.
Downgrading the declaration file
You can use a tool like downlevel-dts(opens in a new tab) to try to downgrade the declaration file from Nutrient to TypeScript 3.4.
- Follow the instructions in the project and run the tool pointing to the declaration file that PSPDKFit ships with (usually under node_modules/pspdfkit/dist/index.d.ts).
- Copy the resulting declaration file to your project.
- Modify your tsconfig.jsonfile with something like the following:
{  "compilerOptions": {    "baseUrl": "./",    "paths": {      "pspdfkit": ["src/pspdfkit.d.ts"]    }  }}Replace src/pspdfkit.d.ts with the location of the transpiled copy of the Nutrient declaration type.
Skipping type declarations for Nutrient
As a last resource, you can generate a new blank declaration file for the pspdfkit module and skip all declarations we offer.
- Create a new declaration file — e.g. pspdfkit.d.ts— as part of your project. If you already have an existing declaration file, you can skip this step.
- Add the declare module "pspdfkit";line to it.
- Modify your tsconfig.jsonfile with something like the following:
{  "compilerOptions": {    "baseUrl": "./",    "paths": {      "pspdfkit": ["src/pspdfkit.d.ts"]    }  }}Replace src/pspdfkit.d.ts with the correct path to your declaration file.
Note that this is a last resort, and when doing this, all type declarations for Nutrient Web SDK in your project will be lost.
 
  
  
  
 