Top-level ‘await’ expressions are only allowed when the ‘module’ option is set to ‘esnext'

35,792

Solution 1

You can wrap your code for const account inside an async function as your target option doesn't support top level await.

 const account = async () => {
        await stripe.accounts.create({
          type: "express",
  });
};

It depends on your code whether you want to return something or you want to perform some other tasks after await.

Incase if you want to use top level await, More about using top level await is on https://stackoverflow.com/a/56590390/9423152

This it just a workaround of the problem not the exact solution as referred by other users. Furthermore, You can try changing the module option and target in tsconfig file if you are using Typescript on node.

Solution 2

To fix the error and use top level await

Here's something you may have missed:

tsc ignores the configuration in tsconfig.json when provided with a file name to compile.

Solution 1 - specify a ts file explicitly and use command line args to provide the right options:

$ npx tsc --help
tsc: The TypeScript Compiler - Version 4.6.2
                                                                                                                     TS
COMMON COMMANDS

  ....

  tsc app.ts util.ts
  Ignoring tsconfig.json, compiles the specified files with default compiler options.

So you'll need to use:

npx tsc -t es2022 -m es2022 --moduleResolution node --outDir dist src/runme.mts

Solution 2 - use tsc specifying the .ts file using src in tsconfig.json

Here's a config with the correct settings for top level await:

{
  // https://www.typescriptlang.org/tsconfig#compilerOptions
  "compilerOptions": {
    "esModuleInterop": true,
    "lib": ["es2020"],
    "module": "es2022",
    "preserveConstEnums": true,
    "moduleResolution": "node",
    "strict": true,
    "sourceMap": true,
    "target": "es2022",
    "types": ["node"],
    "outDir": "dist"
  },
  "include": ["src/**/*"],
  "exclude": ["node_modules"]
}

Make sure the include folders in your tsconfig.json contain your typescript that uses top level await:

npx tsc

dist/runme.mjs is generated and my compiled app runs.

Share:
35,792

Related videos on Youtube

Kev Wats
Author by

Kev Wats

answer my questions, ill give u reputation! :)

Updated on May 11, 2022

Comments

  • Kev Wats
    Kev Wats about 2 years

    I am going through Stripes integration steps and have come across an error for my code found in step 2.1 (https://stripe.com/docs/connect/collect-then-transfer-guide#create-an-account-link)

    How do I fix this error?

    Code:

    const stripe = require('stripe')('someID');
    const account = await stripe.accounts.create({
      type: 'express',
    });
    

    Error:

    Top-level 'await' expressions are only allowed when the 'module' option is set to 'esnext' or 'system', and the 'target' option is set to 'es2017' or higher.ts(1378)

    • Bibek
      Bibek about 3 years
      which means you need to wrap your await expression with async function or do some extra configuration to support top level await.
    • weberc2
      weberc2 over 2 years
      Apparently even if you change your configuration, tsc ignores your tsconfig.json if you pass files explicitly.
    • mikemaccana
      mikemaccana over 2 years
      @Bibek that's not true, you should be able to use top level await (ie with no wrapper async function) as the error mentions, provided the tsconfig.json options are correct.
    • mikemaccana
      mikemaccana about 2 years
      @weberc2 do you have a reference for that?
    • weberc2
      weberc2 about 2 years
      @mikemaccana no, I found that out the hard way. :/
    • mikemaccana
      mikemaccana about 2 years
      @weberc2 I did some research and found a reference for it (and a workaround)- I’ve added an answer below with two solutions.
    • Liam
      Liam about 2 years
      Does this answer your question? Using await outside of an async function
  • Gabriel Arghire
    Gabriel Arghire almost 3 years
    On the link you provided, #1 worked for me. I had to wrap it in an async function.
  • mikemaccana
    mikemaccana over 2 years
    This is a workaround showing the user how to avoid using top level await, rather than an answer. As the error mentions, you should be able to use top level await (ie with no wrapper async function) as the error mentions, provided the tsconfig.json options are correct.
  • inoabrian
    inoabrian about 2 years
    This is not an answer to the question OP posted.