Skip to content

$Fetch.create parametter type #453

@benavern

Description

@benavern

Environment

"nuxt": "^3.13.2"
"typescript": "^5.6.3",
"vue-tsc": "^2.1.6"

Reproduction

This is just a type bug that I have in my project, I found a solution that could / seems to fix the bug and wanted to discuss it here

Describe the bug

when using $fetch.create() with the first parameter (defaults: FetchOptions) explicitely defined in my code as of type FetchOptions<'json'> I see an error (pasted in the Log part of this issue)

Additional context

after trying a large number of solutions, I have found that in the $Fetch type definition, the create method ha no generic attached on the first argument.

interface $Fetch {
    <T = any, R extends ResponseType = "json">(request: FetchRequest, options?: FetchOptions<R>): Promise<MappedResponseType<R, T>>;
    raw<T = any, R extends ResponseType = "json">(request: FetchRequest, options?: FetchOptions<R>): Promise<FetchResponse<MappedResponseType<R, T>>>;
    native: Fetch;
-    create(defaults: FetchOptions, globalOptions?: CreateFetchOptions): $Fetch;
+    create(defaults: FetchOptions<R>, globalOptions?: CreateFetchOptions): $Fetch;
}

this simple change seems to fix my issue. I don't know it this is the right solution though...

Logs

Argument of type '{ responseType: "json"; baseURL: string; body?: RequestInit["body"] | Record<string, any>; ignoreResponseError?: boolean; params?: Record<string, any>; query?: Record<string, any>; ... 24 more ...; onResponseError?: MaybeArray<...> | undefined; }' is not assignable to parameter of type 'FetchOptions<ResponseType, any>'.
  Types of property 'retryDelay' are incompatible.
    Type 'number | ((context: FetchContext<any, "json">) => number) | undefined' is not assignable to type 'number | ((context: FetchContext<any, ResponseType>) => number) | undefined'.
      Type '(context: FetchContext<any, "json">) => number' is not assignable to type 'number | ((context: FetchContext<any, ResponseType>) => number) | undefined'.
        Type '(context: FetchContext<any, "json">) => number' is not assignable to type '(context: FetchContext<any, ResponseType>) => number'.
          Types of parameters 'context' and 'context' are incompatible.
            Type 'FetchContext<any, ResponseType>' is not assignable to type 'FetchContext<any, "json">'.
              Type 'ResponseType' is not assignable to type '"json"'.
                Type '"text"' is not assignable to type '"json"'.

Edit:
I tried this in my project: #371

This seams to fix my problem, but can't confirm as of now...

Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't working

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions