From 7050b082d08432b5b87b492349376f73b268b29c Mon Sep 17 00:00:00 2001 From: Roland Weiss Date: Tue, 7 Apr 2026 15:28:05 +0200 Subject: [PATCH 1/4] fix: serialize format: date query params as YYYY-MM-DD instead of full ISO timestamp When dates: true is enabled in @hey-api/transformers, query parameters with format: date are typed as Date. Previously, Date objects were serialized via .toISOString() producing full timestamps like 2025-12-17T00:00:00.000Z instead of the expected 2025-12-17. Adds a date option to QuerySerializerOptions and emits per-parameter date format hints in the SDK codegen. All 7 client bundles now check instanceof Date before serializing query params. --- .../@tanstack/meta/client/utils.gen.ts | 11 +- .../@tanstack/meta/core/bodySerializer.gen.ts | 1 + .../openapi-ts-tests/main/test/3.1.x.test.ts | 15 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../2.0.x/form-data/client/utils.gen.ts | 11 +- .../form-data/core/bodySerializer.gen.ts | 1 + .../common/default-class/client/utils.gen.ts | 11 +- .../default-class/core/bodySerializer.gen.ts | 1 + .../common/default/client/utils.gen.ts | 11 +- .../common/default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-nested-classes/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../@hey-api/sdk/default/client/utils.gen.ts | 11 +- .../sdk/default/core/bodySerializer.gen.ts | 1 + .../@hey-api/sdk/instance/client/utils.gen.ts | 11 +- .../sdk/instance/core/bodySerializer.gen.ts | 1 + .../sdk/throwOnError/client/utils.gen.ts | 11 +- .../throwOnError/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../@pinia/colada/asClass/client/utils.gen.ts | 11 +- .../colada/asClass/core/bodySerializer.gen.ts | 1 + .../@pinia/colada/fetch/client/utils.gen.ts | 11 +- .../colada/fetch/core/bodySerializer.gen.ts | 1 + .../asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../preact-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../preact-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../preact-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../react-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../react-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../react-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../useMutation/client/utils.gen.ts | 11 +- .../useMutation/core/bodySerializer.gen.ts | 1 + .../solid-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../solid-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../solid-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../svelte-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../svelte-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../svelte-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../vue-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../vue-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../vue-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../2.0.x/schema-unknown/client/utils.gen.ts | 11 +- .../schema-unknown/core/bodySerializer.gen.ts | 1 + .../security-api-key/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../2.0.x/security-basic/client/utils.gen.ts | 11 +- .../security-basic/core/bodySerializer.gen.ts | 1 + .../2.0.x/security-false/client/utils.gen.ts | 11 +- .../security-false/core/bodySerializer.gen.ts | 1 + .../2.0.x/security-oauth2/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../servers-base-path/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../2.0.x/servers-host/client/utils.gen.ts | 11 +- .../servers-host/core/bodySerializer.gen.ts | 1 + .../2.0.x/servers/client/utils.gen.ts | 11 +- .../2.0.x/servers/core/bodySerializer.gen.ts | 1 + .../transforms-read-write/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../body-binary-format/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.0.x/content-types/client/utils.gen.ts | 11 +- .../content-types/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../common/default-class/client/utils.gen.ts | 11 +- .../default-class/core/bodySerializer.gen.ts | 1 + .../common/default/client/utils.gen.ts | 11 +- .../common/default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-nested-classes/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../@hey-api/sdk/default/client/utils.gen.ts | 11 +- .../sdk/default/core/bodySerializer.gen.ts | 1 + .../@hey-api/sdk/instance/client/utils.gen.ts | 11 +- .../sdk/instance/core/bodySerializer.gen.ts | 1 + .../sdk/throwOnError/client/utils.gen.ts | 11 +- .../throwOnError/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../@pinia/colada/asClass/client/utils.gen.ts | 11 +- .../colada/asClass/core/bodySerializer.gen.ts | 1 + .../@pinia/colada/fetch/client/utils.gen.ts | 11 +- .../colada/fetch/core/bodySerializer.gen.ts | 1 + .../asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../preact-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../preact-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../preact-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../react-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../react-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../react-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../useMutation/client/utils.gen.ts | 11 +- .../useMutation/core/bodySerializer.gen.ts | 1 + .../solid-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../solid-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../solid-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../svelte-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../svelte-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../svelte-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../vue-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../vue-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../vue-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../security-api-key/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.0.x/security-false/client/utils.gen.ts | 11 +- .../security-false/core/bodySerializer.gen.ts | 1 + .../security-http-bearer/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.0.x/security-oauth2/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.0.x/servers/client/utils.gen.ts | 11 +- .../3.0.x/servers/core/bodySerializer.gen.ts | 1 + .../transformers-all-of/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../transformers-array/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../transforms-read-write/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-false/client/utils.gen.ts | 11 +- .../base-url-false/core/bodySerializer.gen.ts | 1 + .../base-url-number/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-strict/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-string/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../clean-false/client/utils.gen.ts | 11 +- .../clean-false/core/bodySerializer.gen.ts | 1 + .../default/client/utils.gen.ts | 11 +- .../default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-optional/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-required/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-node16-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-nodenext-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-false/client/utils.gen.ts | 11 +- .../base-url-false/core/bodySerializer.gen.ts | 1 + .../base-url-number/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-strict/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-string/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../clean-false/client/utils.gen.ts | 11 +- .../clean-false/core/bodySerializer.gen.ts | 1 + .../client-axios/default/client/utils.gen.ts | 11 +- .../default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-optional/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-required/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-node16-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-nodenext-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-false/client/utils.gen.ts | 11 +- .../base-url-false/core/bodySerializer.gen.ts | 1 + .../base-url-number/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-strict/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-string/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../clean-false/client/utils.gen.ts | 11 +- .../clean-false/core/bodySerializer.gen.ts | 1 + .../client-fetch/default/client/utils.gen.ts | 11 +- .../default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-optional/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-required/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-node16-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-nodenext-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-false/client/utils.gen.ts | 11 +- .../base-url-false/core/bodySerializer.gen.ts | 1 + .../base-url-number/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-strict/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-string/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client-ky/clean-false/client/utils.gen.ts | 11 +- .../clean-false/core/bodySerializer.gen.ts | 1 + .../client-ky/default/client/utils.gen.ts | 11 +- .../default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-optional/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-required/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-node16-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-nodenext-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-false/client/utils.gen.ts | 11 +- .../base-url-false/core/bodySerializer.gen.ts | 1 + .../base-url-number/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-strict/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-string/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../clean-false/client/utils.gen.ts | 11 +- .../clean-false/core/bodySerializer.gen.ts | 1 + .../client-next/default/client/utils.gen.ts | 11 +- .../default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-optional/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-required/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-node16-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-nodenext-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-false/client/utils.gen.ts | 11 +- .../base-url-false/core/bodySerializer.gen.ts | 1 + .../base-url-number/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-strict/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-string/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../clean-false/client/utils.gen.ts | 11 +- .../clean-false/core/bodySerializer.gen.ts | 1 + .../client-nuxt/default/client/utils.gen.ts | 11 +- .../default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-optional/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-required/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-node16-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-nodenext-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-false/client/utils.gen.ts | 11 +- .../base-url-false/core/bodySerializer.gen.ts | 1 + .../base-url-number/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-strict/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../base-url-string/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../clean-false/client/utils.gen.ts | 11 +- .../clean-false/core/bodySerializer.gen.ts | 1 + .../client-ofetch/default/client/utils.gen.ts | 11 +- .../default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-optional/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-client-required/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-node16-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../tsconfig-nodenext-sdk/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.1.x/content-types/client/utils.gen.ts | 11 +- .../content-types/core/bodySerializer.gen.ts | 1 + .../3.1.x/headers/client/utils.gen.ts | 11 +- .../3.1.x/headers/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.1.x/pagination-ref/client/utils.gen.ts | 11 +- .../pagination-ref/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../common/default-class/client/utils.gen.ts | 11 +- .../default-class/core/bodySerializer.gen.ts | 1 + .../common/default/client/utils.gen.ts | 11 +- .../common/default/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../sdk-nested-classes/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../@hey-api/sdk/default/client/utils.gen.ts | 11 +- .../sdk/default/core/bodySerializer.gen.ts | 1 + .../@hey-api/sdk/instance/client/utils.gen.ts | 11 +- .../sdk/instance/core/bodySerializer.gen.ts | 1 + .../sdk/throwOnError/client/utils.gen.ts | 11 +- .../throwOnError/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../@pinia/colada/asClass/client/utils.gen.ts | 11 +- .../colada/asClass/core/bodySerializer.gen.ts | 1 + .../@pinia/colada/fetch/client/utils.gen.ts | 11 +- .../colada/fetch/core/bodySerializer.gen.ts | 1 + .../asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../preact-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../preact-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../preact-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../react-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../react-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../react-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../useMutation/client/utils.gen.ts | 11 +- .../useMutation/core/bodySerializer.gen.ts | 1 + .../solid-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../solid-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../solid-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../svelte-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../svelte-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../svelte-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../vue-query/asClass/client/utils.gen.ts | 11 +- .../asClass/core/bodySerializer.gen.ts | 1 + .../vue-query/axios/client/utils.gen.ts | 11 +- .../axios/core/bodySerializer.gen.ts | 1 + .../vue-query/fetch/client/utils.gen.ts | 11 +- .../fetch/core/bodySerializer.gen.ts | 1 + .../name-builder/client/utils.gen.ts | 11 +- .../name-builder/core/bodySerializer.gen.ts | 1 + .../security-api-key/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.1.x/security-false/client/utils.gen.ts | 11 +- .../security-false/core/bodySerializer.gen.ts | 1 + .../security-http-bearer/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.1.x/security-oauth2/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../3.1.x/servers/client/utils.gen.ts | 11 +- .../3.1.x/servers/core/bodySerializer.gen.ts | 1 + .../3.1.x/sse-angular/client/utils.gen.ts | 11 +- .../sse-angular/core/bodySerializer.gen.ts | 1 + .../3.1.x/sse-axios/client/utils.gen.ts | 11 +- .../sse-axios/core/bodySerializer.gen.ts | 1 + .../3.1.x/sse-fetch/client/utils.gen.ts | 11 +- .../sse-fetch/core/bodySerializer.gen.ts | 1 + .../3.1.x/sse-next/client/utils.gen.ts | 11 +- .../3.1.x/sse-next/core/bodySerializer.gen.ts | 1 + .../3.1.x/sse-nuxt/client/utils.gen.ts | 11 +- .../3.1.x/sse-nuxt/core/bodySerializer.gen.ts | 1 + .../3.1.x/sse-ofetch/client/utils.gen.ts | 11 +- .../sse-ofetch/core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../transformers-all-of/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../transformers-array/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client.gen.ts | 16 + .../client/client.gen.ts | 298 ++++++++++++++++ .../client/index.ts | 25 ++ .../client/types.gen.ts | 214 ++++++++++++ .../client/utils.gen.ts | 325 ++++++++++++++++++ .../core/auth.gen.ts | 41 +++ .../core/bodySerializer.gen.ts | 83 +++++ .../core/params.gen.ts | 169 +++++++++ .../core/pathSerializer.gen.ts | 171 +++++++++ .../core/queryKeySerializer.gen.ts | 117 +++++++ .../core/serverSentEvents.gen.ts | 242 +++++++++++++ .../core/types.gen.ts | 104 ++++++ .../core/utils.gen.ts | 140 ++++++++ .../transformers-date-query-params/index.ts | 4 + .../transformers-date-query-params/sdk.gen.ts | 27 ++ .../transformers.gen.ts | 9 + .../types.gen.ts | 27 ++ .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../transforms-read-write/client/utils.gen.ts | 11 +- .../core/bodySerializer.gen.ts | 1 + .../@hey-api/client-angular/bundle/utils.ts | 11 +- .../@hey-api/client-axios/bundle/utils.ts | 11 +- .../client-core/bundle/bodySerializer.ts | 1 + .../@hey-api/client-fetch/bundle/utils.ts | 11 +- .../@hey-api/client-ky/bundle/utils.ts | 11 +- .../@hey-api/client-next/bundle/utils.ts | 11 +- .../@hey-api/client-nuxt/bundle/utils.ts | 11 +- .../@hey-api/client-ofetch/bundle/utils.ts | 11 +- .../plugins/@hey-api/sdk/shared/operation.ts | 8 + .../3.1.x/transformers-date-query-params.json | 57 +++ 514 files changed, 4836 insertions(+), 250 deletions(-) create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/client.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/index.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/types.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/utils.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/auth.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/bodySerializer.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/params.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/pathSerializer.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/queryKeySerializer.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/serverSentEvents.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/types.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/utils.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/index.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/sdk.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/transformers.gen.ts create mode 100644 packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/types.gen.ts create mode 100644 specs/3.1.x/transformers-date-query-params.json diff --git a/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/client/utils.gen.ts b/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/client/utils.gen.ts +++ b/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/__snapshots__/plugins/@tanstack/meta/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/3.1.x.test.ts b/packages/openapi-ts-tests/main/test/3.1.x.test.ts index 2ee3cacfe5..fb1a082c02 100644 --- a/packages/openapi-ts-tests/main/test/3.1.x.test.ts +++ b/packages/openapi-ts-tests/main/test/3.1.x.test.ts @@ -888,6 +888,21 @@ describe(`OpenAPI ${version}`, () => { }), description: 'transforms nullable date property', }, + { + config: createConfig({ + input: 'transformers-date-query-params.json', + output: 'transformers-date-query-params', + plugins: [ + '@hey-api/client-fetch', + '@hey-api/transformers', + { + name: '@hey-api/sdk', + transformer: true, + }, + ], + }), + description: 'serializes format: date query params as YYYY-MM-DD', + }, { config: createConfig({ input: 'transformers-array.json', diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/body-response-text-plain/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/form-data/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/schema-unknown/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-api-key/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-basic/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/security-oauth2/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-base-path/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers-host/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/servers/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/2.0.x/transforms-read-write/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-binary-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/body-response-text-plain/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/content-types/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/internal-name-conflict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false-axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/parameter-explode-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@angular/common/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-api-key/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-http-bearer/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-oauth2/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/security-open-id-connect/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/servers/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-all-of/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-any-of-null/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-array/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transformers-recursive/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.0.x/transforms-read-write/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/body-response-text-plain/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-number/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-strict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/base-url-string/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/clean-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/client/utils.gen.ts index aa3335ae1e..0e18068773 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/core/bodySerializer.gen.ts index f6b9521891..0243e9653a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/import-file-extension-ts/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-optional/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/sdk-client-required/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/client/utils.gen.ts index ab0d3ef121..8ca28b9d13 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-node16-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/client/utils.gen.ts index ab0d3ef121..8ca28b9d13 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-angular/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-number/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-strict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/base-url-string/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/clean-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/client/utils.gen.ts index 59fb4dcd11..d5e5288386 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/core/bodySerializer.gen.ts index f6b9521891..0243e9653a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/import-file-extension-ts/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-optional/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/sdk-client-required/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/client/utils.gen.ts index b17878ca42..2296d0cb51 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-node16-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/client/utils.gen.ts index b17878ca42..2296d0cb51 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-axios/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-number/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-strict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/base-url-string/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/clean-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/client/utils.gen.ts index 076fbcd57e..65e43d478a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/core/bodySerializer.gen.ts index f6b9521891..0243e9653a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/import-file-extension-ts/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-optional/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/sdk-client-required/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/client/utils.gen.ts index 09f09a54ce..27b63540b4 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/client/utils.gen.ts index 09f09a54ce..27b63540b4 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-fetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-number/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-strict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/base-url-string/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/clean-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/client/utils.gen.ts index 74a9eb87e8..80fbfaa4de 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/core/bodySerializer.gen.ts index f6b9521891..0243e9653a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/import-file-extension-ts/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-optional/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/sdk-client-required/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/client/utils.gen.ts index 763d58b1bc..331ff28f24 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-node16-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/client/utils.gen.ts index 763d58b1bc..331ff28f24 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ky/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-number/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-strict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/base-url-string/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/clean-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/client/utils.gen.ts index c3c39fef66..3639c95948 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/core/bodySerializer.gen.ts index f6b9521891..0243e9653a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/import-file-extension-ts/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-optional/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/sdk-client-required/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/client/utils.gen.ts index 89c35993f5..563feefc3f 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-node16-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/client/utils.gen.ts index 89c35993f5..563feefc3f 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-next/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-number/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-strict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/base-url-string/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/clean-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/client/utils.gen.ts index e291074850..73b09fbb49 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/core/bodySerializer.gen.ts index f6b9521891..0243e9653a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/import-file-extension-ts/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-optional/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/sdk-client-required/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/client/utils.gen.ts index 3145ae03ae..a6fce07017 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-node16-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/client/utils.gen.ts index 3145ae03ae..a6fce07017 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-nuxt/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-number/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-strict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/base-url-string/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/clean-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/client/utils.gen.ts index e33b1c0719..ecf5ed0f0c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/core/bodySerializer.gen.ts index f6b9521891..0243e9653a 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/import-file-extension-ts/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-optional/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/sdk-client-required/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/client/utils.gen.ts index 3f76679d9a..8755719b76 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-node16-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/client/utils.gen.ts index 3f76679d9a..8755719b76 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts index 71b4bba2ca..e1959c201c 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/clients/@hey-api/client-ofetch/tsconfig-nodenext-sdk/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/content-types/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/headers/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/internal-name-conflict/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/pagination-ref/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false-axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/parameter-explode-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default-class/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@angular/common/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes-instance/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/client-fetch/sdk-nested-classes/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/default/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/instance/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/sdk/throwOnError/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-custom-name/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@hey-api/typescript/transforms-read-write-ignore/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@pinia/colada/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/angular-query-experimental/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/preact-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/react-query/useMutation/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/solid-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/svelte-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/asClass/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/plugins/@tanstack/vue-query/name-builder/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-api-key/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-false/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-http-bearer/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-oauth2/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/security-open-id-connect/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/servers/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/client/utils.gen.ts index 59ca4208d6..d62c60b65e 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/client/utils.gen.ts @@ -108,7 +108,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-angular/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-axios/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-fetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/client/utils.gen.ts index c934c941f2..d081566877 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/client/utils.gen.ts @@ -107,7 +107,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-next/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/client/utils.gen.ts index ce6682c380..fca477e165 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/client/utils.gen.ts @@ -111,7 +111,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-nuxt/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-ofetch/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/sse-tanstack-react-query/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-additional-properties/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-all-of/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-allof-response-wrapper/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-any-of-null/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-array/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client.gen.ts new file mode 100644 index 0000000000..cab3c70195 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client.gen.ts @@ -0,0 +1,16 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import { type ClientOptions, type Config, createClient, createConfig } from './client'; +import type { ClientOptions as ClientOptions2 } from './types.gen'; + +/** + * The `createClientConfig()` function will be called on client initialization + * and the returned object will become the client's initial configuration. + * + * You may want to initialize your client this way instead of calling + * `setConfig()`. This is useful for example if you're using Next.js + * to ensure your client always has the correct values. + */ +export type CreateClientConfig = (override?: Config) => Config & T>; + +export const client = createClient(createConfig()); diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/client.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/client.gen.ts new file mode 100644 index 0000000000..9ec9ad887c --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/client.gen.ts @@ -0,0 +1,298 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import { createSseClient } from '../core/serverSentEvents.gen'; +import type { HttpMethod } from '../core/types.gen'; +import { getValidRequestBody } from '../core/utils.gen'; +import type { Client, Config, RequestOptions, ResolvedRequestOptions } from './types.gen'; +import { + buildUrl, + createConfig, + createInterceptors, + getParseAs, + mergeConfigs, + mergeHeaders, + setAuthParams, +} from './utils.gen'; + +type ReqInit = Omit & { + body?: any; + headers: ReturnType; +}; + +export const createClient = (config: Config = {}): Client => { + let _config = mergeConfigs(createConfig(), config); + + const getConfig = (): Config => ({ ..._config }); + + const setConfig = (config: Config): Config => { + _config = mergeConfigs(_config, config); + return getConfig(); + }; + + const interceptors = createInterceptors(); + + const beforeRequest = async < + TData = unknown, + TResponseStyle extends 'data' | 'fields' = 'fields', + ThrowOnError extends boolean = boolean, + Url extends string = string, + >( + options: RequestOptions, + ) => { + const opts = { + ..._config, + ...options, + fetch: options.fetch ?? _config.fetch ?? globalThis.fetch, + headers: mergeHeaders(_config.headers, options.headers), + serializedBody: undefined as string | undefined, + }; + + if (opts.security) { + await setAuthParams({ + ...opts, + security: opts.security, + }); + } + + if (opts.requestValidator) { + await opts.requestValidator(opts); + } + + if (opts.body !== undefined && opts.bodySerializer) { + opts.serializedBody = opts.bodySerializer(opts.body) as string | undefined; + } + + // remove Content-Type header if body is empty to avoid sending invalid requests + if (opts.body === undefined || opts.serializedBody === '') { + opts.headers.delete('Content-Type'); + } + + const resolvedOpts = opts as typeof opts & + ResolvedRequestOptions; + const url = buildUrl(resolvedOpts); + + return { opts: resolvedOpts, url }; + }; + + const request: Client['request'] = async (options) => { + const { opts, url } = await beforeRequest(options); + const requestInit: ReqInit = { + redirect: 'follow', + ...opts, + body: getValidRequestBody(opts), + }; + + let request = new Request(url, requestInit); + + for (const fn of interceptors.request.fns) { + if (fn) { + request = await fn(request, opts); + } + } + + // fetch must be assigned here, otherwise it would throw the error: + // TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation + const _fetch = opts.fetch!; + let response: Response; + + try { + response = await _fetch(request); + } catch (error) { + // Handle fetch exceptions (AbortError, network errors, etc.) + let finalError = error; + + for (const fn of interceptors.error.fns) { + if (fn) { + finalError = (await fn(error, undefined as any, request, opts)) as unknown; + } + } + + finalError = finalError || ({} as unknown); + + if (opts.throwOnError) { + throw finalError; + } + + // Return error response + return opts.responseStyle === 'data' + ? undefined + : { + error: finalError, + request, + response: undefined as any, + }; + } + + for (const fn of interceptors.response.fns) { + if (fn) { + response = await fn(response, request, opts); + } + } + + const result = { + request, + response, + }; + + if (response.ok) { + const parseAs = + (opts.parseAs === 'auto' + ? getParseAs(response.headers.get('Content-Type')) + : opts.parseAs) ?? 'json'; + + if (response.status === 204 || response.headers.get('Content-Length') === '0') { + let emptyData: any; + switch (parseAs) { + case 'arrayBuffer': + case 'blob': + case 'text': + emptyData = await response[parseAs](); + break; + case 'formData': + emptyData = new FormData(); + break; + case 'stream': + emptyData = response.body; + break; + case 'json': + default: + emptyData = {}; + break; + } + return opts.responseStyle === 'data' + ? emptyData + : { + data: emptyData, + ...result, + }; + } + + let data: any; + switch (parseAs) { + case 'arrayBuffer': + case 'blob': + case 'formData': + case 'text': + data = await response[parseAs](); + break; + case 'json': { + // Some servers return 200 with no Content-Length and empty body. + // response.json() would throw; read as text and parse if non-empty. + const text = await response.text(); + data = text ? JSON.parse(text) : {}; + break; + } + case 'stream': + return opts.responseStyle === 'data' + ? response.body + : { + data: response.body, + ...result, + }; + } + + if (parseAs === 'json') { + if (opts.responseValidator) { + await opts.responseValidator(data); + } + + if (opts.responseTransformer) { + data = await opts.responseTransformer(data); + } + } + + return opts.responseStyle === 'data' + ? data + : { + data, + ...result, + }; + } + + const textError = await response.text(); + let jsonError: unknown; + + try { + jsonError = JSON.parse(textError); + } catch { + // noop + } + + const error = jsonError ?? textError; + let finalError = error; + + for (const fn of interceptors.error.fns) { + if (fn) { + finalError = (await fn(error, response, request, opts)) as string; + } + } + + finalError = finalError || ({} as string); + + if (opts.throwOnError) { + throw finalError; + } + + // TODO: we probably want to return error and improve types + return opts.responseStyle === 'data' + ? undefined + : { + error: finalError, + ...result, + }; + }; + + const makeMethodFn = (method: Uppercase) => (options: RequestOptions) => + request({ ...options, method }); + + const makeSseFn = (method: Uppercase) => async (options: RequestOptions) => { + const { opts, url } = await beforeRequest(options); + return createSseClient({ + ...opts, + body: opts.body as BodyInit | null | undefined, + headers: opts.headers as unknown as Record, + method, + onRequest: async (url, init) => { + let request = new Request(url, init); + for (const fn of interceptors.request.fns) { + if (fn) { + request = await fn(request, opts); + } + } + return request; + }, + serializedBody: getValidRequestBody(opts) as BodyInit | null | undefined, + url, + }); + }; + + const _buildUrl: Client['buildUrl'] = (options) => buildUrl({ ..._config, ...options }); + + return { + buildUrl: _buildUrl, + connect: makeMethodFn('CONNECT'), + delete: makeMethodFn('DELETE'), + get: makeMethodFn('GET'), + getConfig, + head: makeMethodFn('HEAD'), + interceptors, + options: makeMethodFn('OPTIONS'), + patch: makeMethodFn('PATCH'), + post: makeMethodFn('POST'), + put: makeMethodFn('PUT'), + request, + setConfig, + sse: { + connect: makeSseFn('CONNECT'), + delete: makeSseFn('DELETE'), + get: makeSseFn('GET'), + head: makeSseFn('HEAD'), + options: makeSseFn('OPTIONS'), + patch: makeSseFn('PATCH'), + post: makeSseFn('POST'), + put: makeSseFn('PUT'), + trace: makeSseFn('TRACE'), + }, + trace: makeMethodFn('TRACE'), + } as Client; +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/index.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/index.ts new file mode 100644 index 0000000000..b295edeca0 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/index.ts @@ -0,0 +1,25 @@ +// This file is auto-generated by @hey-api/openapi-ts + +export type { Auth } from '../core/auth.gen'; +export type { QuerySerializerOptions } from '../core/bodySerializer.gen'; +export { + formDataBodySerializer, + jsonBodySerializer, + urlSearchParamsBodySerializer, +} from '../core/bodySerializer.gen'; +export { buildClientParams } from '../core/params.gen'; +export { serializeQueryKeyValue } from '../core/queryKeySerializer.gen'; +export { createClient } from './client.gen'; +export type { + Client, + ClientOptions, + Config, + CreateClientConfig, + Options, + RequestOptions, + RequestResult, + ResolvedRequestOptions, + ResponseStyle, + TDataShape, +} from './types.gen'; +export { createConfig, mergeHeaders } from './utils.gen'; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/types.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/types.gen.ts new file mode 100644 index 0000000000..9813eeaba6 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/types.gen.ts @@ -0,0 +1,214 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import type { Auth } from '../core/auth.gen'; +import type { + ServerSentEventsOptions, + ServerSentEventsResult, +} from '../core/serverSentEvents.gen'; +import type { Client as CoreClient, Config as CoreConfig } from '../core/types.gen'; +import type { Middleware } from './utils.gen'; + +export type ResponseStyle = 'data' | 'fields'; + +export interface Config + extends Omit, CoreConfig { + /** + * Base URL for all requests made by this client. + */ + baseUrl?: T['baseUrl']; + /** + * Fetch API implementation. You can use this option to provide a custom + * fetch instance. + * + * @default globalThis.fetch + */ + fetch?: typeof fetch; + /** + * Please don't use the Fetch client for Next.js applications. The `next` + * options won't have any effect. + * + * Install {@link https://www.npmjs.com/package/@hey-api/client-next `@hey-api/client-next`} instead. + */ + next?: never; + /** + * Return the response data parsed in a specified format. By default, `auto` + * will infer the appropriate method from the `Content-Type` response header. + * You can override this behavior with any of the {@link Body} methods. + * Select `stream` if you don't want to parse response data at all. + * + * @default 'auto' + */ + parseAs?: 'arrayBuffer' | 'auto' | 'blob' | 'formData' | 'json' | 'stream' | 'text'; + /** + * Should we return only data or multiple fields (data, error, response, etc.)? + * + * @default 'fields' + */ + responseStyle?: ResponseStyle; + /** + * Throw an error instead of returning it in the response? + * + * @default false + */ + throwOnError?: T['throwOnError']; +} + +export interface RequestOptions< + TData = unknown, + TResponseStyle extends ResponseStyle = 'fields', + ThrowOnError extends boolean = boolean, + Url extends string = string, +> + extends + Config<{ + responseStyle: TResponseStyle; + throwOnError: ThrowOnError; + }>, + Pick< + ServerSentEventsOptions, + | 'onRequest' + | 'onSseError' + | 'onSseEvent' + | 'sseDefaultRetryDelay' + | 'sseMaxRetryAttempts' + | 'sseMaxRetryDelay' + > { + /** + * Any body that you want to add to your request. + * + * {@link https://developer.mozilla.org/docs/Web/API/fetch#body} + */ + body?: unknown; + path?: Record; + query?: Record; + /** + * Security mechanism(s) to use for the request. + */ + security?: ReadonlyArray; + url: Url; +} + +export interface ResolvedRequestOptions< + TResponseStyle extends ResponseStyle = 'fields', + ThrowOnError extends boolean = boolean, + Url extends string = string, +> extends RequestOptions { + serializedBody?: string; +} + +export type RequestResult< + TData = unknown, + TError = unknown, + ThrowOnError extends boolean = boolean, + TResponseStyle extends ResponseStyle = 'fields', +> = ThrowOnError extends true + ? Promise< + TResponseStyle extends 'data' + ? TData extends Record + ? TData[keyof TData] + : TData + : { + data: TData extends Record ? TData[keyof TData] : TData; + request: Request; + response: Response; + } + > + : Promise< + TResponseStyle extends 'data' + ? (TData extends Record ? TData[keyof TData] : TData) | undefined + : ( + | { + data: TData extends Record ? TData[keyof TData] : TData; + error: undefined; + } + | { + data: undefined; + error: TError extends Record ? TError[keyof TError] : TError; + } + ) & { + request: Request; + response: Response; + } + >; + +export interface ClientOptions { + baseUrl?: string; + responseStyle?: ResponseStyle; + throwOnError?: boolean; +} + +type MethodFn = < + TData = unknown, + TError = unknown, + ThrowOnError extends boolean = false, + TResponseStyle extends ResponseStyle = 'fields', +>( + options: Omit, 'method'>, +) => RequestResult; + +type SseFn = < + TData = unknown, + TError = unknown, + ThrowOnError extends boolean = false, + TResponseStyle extends ResponseStyle = 'fields', +>( + options: Omit, 'method'>, +) => Promise>; + +type RequestFn = < + TData = unknown, + TError = unknown, + ThrowOnError extends boolean = false, + TResponseStyle extends ResponseStyle = 'fields', +>( + options: Omit, 'method'> & + Pick>, 'method'>, +) => RequestResult; + +type BuildUrlFn = < + TData extends { + body?: unknown; + path?: Record; + query?: Record; + url: string; + }, +>( + options: TData & Options, +) => string; + +export type Client = CoreClient & { + interceptors: Middleware; +}; + +/** + * The `createClientConfig()` function will be called on client initialization + * and the returned object will become the client's initial configuration. + * + * You may want to initialize your client this way instead of calling + * `setConfig()`. This is useful for example if you're using Next.js + * to ensure your client always has the correct values. + */ +export type CreateClientConfig = ( + override?: Config, +) => Config & T>; + +export interface TDataShape { + body?: unknown; + headers?: unknown; + path?: unknown; + query?: unknown; + url: string; +} + +type OmitKeys = Pick>; + +export type Options< + TData extends TDataShape = TDataShape, + ThrowOnError extends boolean = boolean, + TResponse = unknown, + TResponseStyle extends ResponseStyle = 'fields', +> = OmitKeys< + RequestOptions, + 'body' | 'path' | 'query' | 'url' +> & + ([TData] extends [never] ? unknown : Omit); diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/utils.gen.ts new file mode 100644 index 0000000000..32431a9f15 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/client/utils.gen.ts @@ -0,0 +1,325 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import { getAuthToken } from '../core/auth.gen'; +import type { QuerySerializerOptions } from '../core/bodySerializer.gen'; +import { jsonBodySerializer } from '../core/bodySerializer.gen'; +import { + serializeArrayParam, + serializeObjectParam, + serializePrimitiveParam, +} from '../core/pathSerializer.gen'; +import { getUrl } from '../core/utils.gen'; +import type { Client, ClientOptions, Config, RequestOptions } from './types.gen'; + +export const createQuerySerializer = ({ + parameters = {}, + ...args +}: QuerySerializerOptions = {}) => { + const querySerializer = (queryParams: T) => { + const search: string[] = []; + if (queryParams && typeof queryParams === 'object') { + for (const name in queryParams) { + const value = queryParams[name]; + + if (value === undefined || value === null) { + continue; + } + + const options = parameters[name] || args; + + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { + const serializedArray = serializeArrayParam({ + allowReserved: options.allowReserved, + explode: true, + name, + style: 'form', + value, + ...options.array, + }); + if (serializedArray) search.push(serializedArray); + } else if (typeof value === 'object') { + const serializedObject = serializeObjectParam({ + allowReserved: options.allowReserved, + explode: true, + name, + style: 'deepObject', + value: value as Record, + ...options.object, + }); + if (serializedObject) search.push(serializedObject); + } else { + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: value as string, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } + } + } + return search.join('&'); + }; + return querySerializer; +}; + +/** + * Infers parseAs value from provided Content-Type header. + */ +export const getParseAs = (contentType: string | null): Exclude => { + if (!contentType) { + // If no Content-Type header is provided, the best we can do is return the raw response body, + // which is effectively the same as the 'stream' option. + return 'stream'; + } + + const cleanContent = contentType.split(';')[0]?.trim(); + + if (!cleanContent) { + return; + } + + if (cleanContent.startsWith('application/json') || cleanContent.endsWith('+json')) { + return 'json'; + } + + if (cleanContent === 'multipart/form-data') { + return 'formData'; + } + + if ( + ['application/', 'audio/', 'image/', 'video/'].some((type) => cleanContent.startsWith(type)) + ) { + return 'blob'; + } + + if (cleanContent.startsWith('text/')) { + return 'text'; + } + + return; +}; + +const checkForExistence = ( + options: Pick & { + headers: Headers; + }, + name?: string, +): boolean => { + if (!name) { + return false; + } + if ( + options.headers.has(name) || + options.query?.[name] || + options.headers.get('Cookie')?.includes(`${name}=`) + ) { + return true; + } + return false; +}; + +export const setAuthParams = async ({ + security, + ...options +}: Pick, 'security'> & + Pick & { + headers: Headers; + }) => { + for (const auth of security) { + if (checkForExistence(options, auth.name)) { + continue; + } + + const token = await getAuthToken(auth, options.auth); + + if (!token) { + continue; + } + + const name = auth.name ?? 'Authorization'; + + switch (auth.in) { + case 'query': + if (!options.query) { + options.query = {}; + } + options.query[name] = token; + break; + case 'cookie': + options.headers.append('Cookie', `${name}=${token}`); + break; + case 'header': + default: + options.headers.set(name, token); + break; + } + } +}; + +export const buildUrl: Client['buildUrl'] = (options) => + getUrl({ + baseUrl: options.baseUrl as string, + path: options.path, + query: options.query, + querySerializer: + typeof options.querySerializer === 'function' + ? options.querySerializer + : createQuerySerializer(options.querySerializer), + url: options.url, + }); + +export const mergeConfigs = (a: Config, b: Config): Config => { + const config = { ...a, ...b }; + if (config.baseUrl?.endsWith('/')) { + config.baseUrl = config.baseUrl.substring(0, config.baseUrl.length - 1); + } + config.headers = mergeHeaders(a.headers, b.headers); + return config; +}; + +const headersEntries = (headers: Headers): Array<[string, string]> => { + const entries: Array<[string, string]> = []; + headers.forEach((value, key) => { + entries.push([key, value]); + }); + return entries; +}; + +export const mergeHeaders = ( + ...headers: Array['headers'] | undefined> +): Headers => { + const mergedHeaders = new Headers(); + for (const header of headers) { + if (!header) { + continue; + } + + const iterator = header instanceof Headers ? headersEntries(header) : Object.entries(header); + + for (const [key, value] of iterator) { + if (value === null) { + mergedHeaders.delete(key); + } else if (Array.isArray(value)) { + for (const v of value) { + mergedHeaders.append(key, v as string); + } + } else if (value !== undefined) { + // assume object headers are meant to be JSON stringified, i.e., their + // content value in OpenAPI specification is 'application/json' + mergedHeaders.set( + key, + typeof value === 'object' ? JSON.stringify(value) : (value as string), + ); + } + } + } + return mergedHeaders; +}; + +type ErrInterceptor = ( + error: Err, + response: Res, + request: Req, + options: Options, +) => Err | Promise; + +type ReqInterceptor = (request: Req, options: Options) => Req | Promise; + +type ResInterceptor = ( + response: Res, + request: Req, + options: Options, +) => Res | Promise; + +class Interceptors { + fns: Array = []; + + clear(): void { + this.fns = []; + } + + eject(id: number | Interceptor): void { + const index = this.getInterceptorIndex(id); + if (this.fns[index]) { + this.fns[index] = null; + } + } + + exists(id: number | Interceptor): boolean { + const index = this.getInterceptorIndex(id); + return Boolean(this.fns[index]); + } + + getInterceptorIndex(id: number | Interceptor): number { + if (typeof id === 'number') { + return this.fns[id] ? id : -1; + } + return this.fns.indexOf(id); + } + + update(id: number | Interceptor, fn: Interceptor): number | Interceptor | false { + const index = this.getInterceptorIndex(id); + if (this.fns[index]) { + this.fns[index] = fn; + return id; + } + return false; + } + + use(fn: Interceptor): number { + this.fns.push(fn); + return this.fns.length - 1; + } +} + +export interface Middleware { + error: Interceptors>; + request: Interceptors>; + response: Interceptors>; +} + +export const createInterceptors = (): Middleware< + Req, + Res, + Err, + Options +> => ({ + error: new Interceptors>(), + request: new Interceptors>(), + response: new Interceptors>(), +}); + +const defaultQuerySerializer = createQuerySerializer({ + allowReserved: false, + array: { + explode: true, + style: 'form', + }, + object: { + explode: true, + style: 'deepObject', + }, +}); + +const defaultHeaders = { + 'Content-Type': 'application/json', +}; + +export const createConfig = ( + override: Config & T> = {}, +): Config & T> => ({ + ...jsonBodySerializer, + headers: defaultHeaders, + parseAs: 'auto', + querySerializer: defaultQuerySerializer, + ...override, +}); diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/auth.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/auth.gen.ts new file mode 100644 index 0000000000..3ebf994788 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/auth.gen.ts @@ -0,0 +1,41 @@ +// This file is auto-generated by @hey-api/openapi-ts + +export type AuthToken = string | undefined; + +export interface Auth { + /** + * Which part of the request do we use to send the auth? + * + * @default 'header' + */ + in?: 'header' | 'query' | 'cookie'; + /** + * Header or query parameter name. + * + * @default 'Authorization' + */ + name?: string; + scheme?: 'basic' | 'bearer'; + type: 'apiKey' | 'http'; +} + +export const getAuthToken = async ( + auth: Auth, + callback: ((auth: Auth) => Promise | AuthToken) | AuthToken, +): Promise => { + const token = typeof callback === 'function' ? await callback(auth) : callback; + + if (!token) { + return; + } + + if (auth.scheme === 'bearer') { + return `Bearer ${token}`; + } + + if (auth.scheme === 'basic') { + return `Basic ${btoa(token)}`; + } + + return token; +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/bodySerializer.gen.ts new file mode 100644 index 0000000000..dd36c4a3a3 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/bodySerializer.gen.ts @@ -0,0 +1,83 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import type { ArrayStyle, ObjectStyle, SerializerOptions } from './pathSerializer.gen'; + +export type QuerySerializer = (query: Record) => string; + +export type BodySerializer = (body: unknown) => unknown; + +type QuerySerializerOptionsObject = { + allowReserved?: boolean; + array?: Partial>; + date?: 'date' | 'date-time'; + object?: Partial>; +}; + +export type QuerySerializerOptions = QuerySerializerOptionsObject & { + /** + * Per-parameter serialization overrides. When provided, these settings + * override the global array/object settings for specific parameter names. + */ + parameters?: Record; +}; + +const serializeFormDataPair = (data: FormData, key: string, value: unknown): void => { + if (typeof value === 'string' || value instanceof Blob) { + data.append(key, value); + } else if (value instanceof Date) { + data.append(key, value.toISOString()); + } else { + data.append(key, JSON.stringify(value)); + } +}; + +const serializeUrlSearchParamsPair = (data: URLSearchParams, key: string, value: unknown): void => { + if (typeof value === 'string') { + data.append(key, value); + } else { + data.append(key, JSON.stringify(value)); + } +}; + +export const formDataBodySerializer = { + bodySerializer: (body: unknown): FormData => { + const data = new FormData(); + + Object.entries(body as Record).forEach(([key, value]) => { + if (value === undefined || value === null) { + return; + } + if (Array.isArray(value)) { + value.forEach((v) => serializeFormDataPair(data, key, v)); + } else { + serializeFormDataPair(data, key, value); + } + }); + + return data; + }, +}; + +export const jsonBodySerializer = { + bodySerializer: (body: unknown): string => + JSON.stringify(body, (_key, value) => (typeof value === 'bigint' ? value.toString() : value)), +}; + +export const urlSearchParamsBodySerializer = { + bodySerializer: (body: unknown): string => { + const data = new URLSearchParams(); + + Object.entries(body as Record).forEach(([key, value]) => { + if (value === undefined || value === null) { + return; + } + if (Array.isArray(value)) { + value.forEach((v) => serializeUrlSearchParamsPair(data, key, v)); + } else { + serializeUrlSearchParamsPair(data, key, value); + } + }); + + return data.toString(); + }, +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/params.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/params.gen.ts new file mode 100644 index 0000000000..7955601a5c --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/params.gen.ts @@ -0,0 +1,169 @@ +// This file is auto-generated by @hey-api/openapi-ts + +type Slot = 'body' | 'headers' | 'path' | 'query'; + +export type Field = + | { + in: Exclude; + /** + * Field name. This is the name we want the user to see and use. + */ + key: string; + /** + * Field mapped name. This is the name we want to use in the request. + * If omitted, we use the same value as `key`. + */ + map?: string; + } + | { + in: Extract; + /** + * Key isn't required for bodies. + */ + key?: string; + map?: string; + } + | { + /** + * Field name. This is the name we want the user to see and use. + */ + key: string; + /** + * Field mapped name. This is the name we want to use in the request. + * If `in` is omitted, `map` aliases `key` to the transport layer. + */ + map: Slot; + }; + +export interface Fields { + allowExtra?: Partial>; + args?: ReadonlyArray; +} + +export type FieldsConfig = ReadonlyArray; + +const extraPrefixesMap: Record = { + $body_: 'body', + $headers_: 'headers', + $path_: 'path', + $query_: 'query', +}; +const extraPrefixes = Object.entries(extraPrefixesMap); + +type KeyMap = Map< + string, + | { + in: Slot; + map?: string; + } + | { + in?: never; + map: Slot; + } +>; + +const buildKeyMap = (fields: FieldsConfig, map?: KeyMap): KeyMap => { + if (!map) { + map = new Map(); + } + + for (const config of fields) { + if ('in' in config) { + if (config.key) { + map.set(config.key, { + in: config.in, + map: config.map, + }); + } + } else if ('key' in config) { + map.set(config.key, { + map: config.map, + }); + } else if (config.args) { + buildKeyMap(config.args, map); + } + } + + return map; +}; + +interface Params { + body: unknown; + headers: Record; + path: Record; + query: Record; +} + +const stripEmptySlots = (params: Params) => { + for (const [slot, value] of Object.entries(params)) { + if (value && typeof value === 'object' && !Array.isArray(value) && !Object.keys(value).length) { + delete params[slot as Slot]; + } + } +}; + +export const buildClientParams = (args: ReadonlyArray, fields: FieldsConfig) => { + const params: Params = { + body: {}, + headers: {}, + path: {}, + query: {}, + }; + + const map = buildKeyMap(fields); + + let config: FieldsConfig[number] | undefined; + + for (const [index, arg] of args.entries()) { + if (fields[index]) { + config = fields[index]; + } + + if (!config) { + continue; + } + + if ('in' in config) { + if (config.key) { + const field = map.get(config.key)!; + const name = field.map || config.key; + if (field.in) { + (params[field.in] as Record)[name] = arg; + } + } else { + params.body = arg; + } + } else { + for (const [key, value] of Object.entries(arg ?? {})) { + const field = map.get(key); + + if (field) { + if (field.in) { + const name = field.map || key; + (params[field.in] as Record)[name] = value; + } else { + params[field.map] = value; + } + } else { + const extra = extraPrefixes.find(([prefix]) => key.startsWith(prefix)); + + if (extra) { + const [prefix, slot] = extra; + (params[slot] as Record)[key.slice(prefix.length)] = value; + } else if ('allowExtra' in config && config.allowExtra) { + for (const [slot, allowed] of Object.entries(config.allowExtra)) { + if (allowed) { + (params[slot as Slot] as Record)[key] = value; + break; + } + } + } + } + } + } + } + + stripEmptySlots(params); + + return params; +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/pathSerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/pathSerializer.gen.ts new file mode 100644 index 0000000000..994b2848c6 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/pathSerializer.gen.ts @@ -0,0 +1,171 @@ +// This file is auto-generated by @hey-api/openapi-ts + +interface SerializeOptions extends SerializePrimitiveOptions, SerializerOptions {} + +interface SerializePrimitiveOptions { + allowReserved?: boolean; + name: string; +} + +export interface SerializerOptions { + /** + * @default true + */ + explode: boolean; + style: T; +} + +export type ArrayStyle = 'form' | 'spaceDelimited' | 'pipeDelimited'; +export type ArraySeparatorStyle = ArrayStyle | MatrixStyle; +type MatrixStyle = 'label' | 'matrix' | 'simple'; +export type ObjectStyle = 'form' | 'deepObject'; +type ObjectSeparatorStyle = ObjectStyle | MatrixStyle; + +interface SerializePrimitiveParam extends SerializePrimitiveOptions { + value: string; +} + +export const separatorArrayExplode = (style: ArraySeparatorStyle) => { + switch (style) { + case 'label': + return '.'; + case 'matrix': + return ';'; + case 'simple': + return ','; + default: + return '&'; + } +}; + +export const separatorArrayNoExplode = (style: ArraySeparatorStyle) => { + switch (style) { + case 'form': + return ','; + case 'pipeDelimited': + return '|'; + case 'spaceDelimited': + return '%20'; + default: + return ','; + } +}; + +export const separatorObjectExplode = (style: ObjectSeparatorStyle) => { + switch (style) { + case 'label': + return '.'; + case 'matrix': + return ';'; + case 'simple': + return ','; + default: + return '&'; + } +}; + +export const serializeArrayParam = ({ + allowReserved, + explode, + name, + style, + value, +}: SerializeOptions & { + value: unknown[]; +}) => { + if (!explode) { + const joinedValues = ( + allowReserved ? value : value.map((v) => encodeURIComponent(v as string)) + ).join(separatorArrayNoExplode(style)); + switch (style) { + case 'label': + return `.${joinedValues}`; + case 'matrix': + return `;${name}=${joinedValues}`; + case 'simple': + return joinedValues; + default: + return `${name}=${joinedValues}`; + } + } + + const separator = separatorArrayExplode(style); + const joinedValues = value + .map((v) => { + if (style === 'label' || style === 'simple') { + return allowReserved ? v : encodeURIComponent(v as string); + } + + return serializePrimitiveParam({ + allowReserved, + name, + value: v as string, + }); + }) + .join(separator); + return style === 'label' || style === 'matrix' ? separator + joinedValues : joinedValues; +}; + +export const serializePrimitiveParam = ({ + allowReserved, + name, + value, +}: SerializePrimitiveParam) => { + if (value === undefined || value === null) { + return ''; + } + + if (typeof value === 'object') { + throw new Error( + 'Deeply-nested arrays/objects aren’t supported. Provide your own `querySerializer()` to handle these.', + ); + } + + return `${name}=${allowReserved ? value : encodeURIComponent(value)}`; +}; + +export const serializeObjectParam = ({ + allowReserved, + explode, + name, + style, + value, + valueOnly, +}: SerializeOptions & { + value: Record | Date; + valueOnly?: boolean; +}) => { + if (value instanceof Date) { + return valueOnly ? value.toISOString() : `${name}=${value.toISOString()}`; + } + + if (style !== 'deepObject' && !explode) { + let values: string[] = []; + Object.entries(value).forEach(([key, v]) => { + values = [...values, key, allowReserved ? (v as string) : encodeURIComponent(v as string)]; + }); + const joinedValues = values.join(','); + switch (style) { + case 'form': + return `${name}=${joinedValues}`; + case 'label': + return `.${joinedValues}`; + case 'matrix': + return `;${name}=${joinedValues}`; + default: + return joinedValues; + } + } + + const separator = separatorObjectExplode(style); + const joinedValues = Object.entries(value) + .map(([key, v]) => + serializePrimitiveParam({ + allowReserved, + name: style === 'deepObject' ? `${name}[${key}]` : key, + value: v as string, + }), + ) + .join(separator); + return style === 'label' || style === 'matrix' ? separator + joinedValues : joinedValues; +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/queryKeySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/queryKeySerializer.gen.ts new file mode 100644 index 0000000000..5000df606f --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/queryKeySerializer.gen.ts @@ -0,0 +1,117 @@ +// This file is auto-generated by @hey-api/openapi-ts + +/** + * JSON-friendly union that mirrors what Pinia Colada can hash. + */ +export type JsonValue = + | null + | string + | number + | boolean + | JsonValue[] + | { [key: string]: JsonValue }; + +/** + * Replacer that converts non-JSON values (bigint, Date, etc.) to safe substitutes. + */ +export const queryKeyJsonReplacer = (_key: string, value: unknown) => { + if (value === undefined || typeof value === 'function' || typeof value === 'symbol') { + return undefined; + } + if (typeof value === 'bigint') { + return value.toString(); + } + if (value instanceof Date) { + return value.toISOString(); + } + return value; +}; + +/** + * Safely stringifies a value and parses it back into a JsonValue. + */ +export const stringifyToJsonValue = (input: unknown): JsonValue | undefined => { + try { + const json = JSON.stringify(input, queryKeyJsonReplacer); + if (json === undefined) { + return undefined; + } + return JSON.parse(json) as JsonValue; + } catch { + return undefined; + } +}; + +/** + * Detects plain objects (including objects with a null prototype). + */ +const isPlainObject = (value: unknown): value is Record => { + if (value === null || typeof value !== 'object') { + return false; + } + const prototype = Object.getPrototypeOf(value as object); + return prototype === Object.prototype || prototype === null; +}; + +/** + * Turns URLSearchParams into a sorted JSON object for deterministic keys. + */ +const serializeSearchParams = (params: URLSearchParams): JsonValue => { + const entries = Array.from(params.entries()).sort(([a], [b]) => a.localeCompare(b)); + const result: Record = {}; + + for (const [key, value] of entries) { + const existing = result[key]; + if (existing === undefined) { + result[key] = value; + continue; + } + + if (Array.isArray(existing)) { + (existing as string[]).push(value); + } else { + result[key] = [existing, value]; + } + } + + return result; +}; + +/** + * Normalizes any accepted value into a JSON-friendly shape for query keys. + */ +export const serializeQueryKeyValue = (value: unknown): JsonValue | undefined => { + if (value === null) { + return null; + } + + if (typeof value === 'string' || typeof value === 'number' || typeof value === 'boolean') { + return value; + } + + if (value === undefined || typeof value === 'function' || typeof value === 'symbol') { + return undefined; + } + + if (typeof value === 'bigint') { + return value.toString(); + } + + if (value instanceof Date) { + return value.toISOString(); + } + + if (Array.isArray(value)) { + return stringifyToJsonValue(value); + } + + if (typeof URLSearchParams !== 'undefined' && value instanceof URLSearchParams) { + return serializeSearchParams(value); + } + + if (isPlainObject(value)) { + return stringifyToJsonValue(value); + } + + return undefined; +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/serverSentEvents.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/serverSentEvents.gen.ts new file mode 100644 index 0000000000..ddf3c4d13a --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/serverSentEvents.gen.ts @@ -0,0 +1,242 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import type { Config } from './types.gen'; + +export type ServerSentEventsOptions = Omit & + Pick & { + /** + * Fetch API implementation. You can use this option to provide a custom + * fetch instance. + * + * @default globalThis.fetch + */ + fetch?: typeof fetch; + /** + * Implementing clients can call request interceptors inside this hook. + */ + onRequest?: (url: string, init: RequestInit) => Promise; + /** + * Callback invoked when a network or parsing error occurs during streaming. + * + * This option applies only if the endpoint returns a stream of events. + * + * @param error The error that occurred. + */ + onSseError?: (error: unknown) => void; + /** + * Callback invoked when an event is streamed from the server. + * + * This option applies only if the endpoint returns a stream of events. + * + * @param event Event streamed from the server. + * @returns Nothing (void). + */ + onSseEvent?: (event: StreamEvent) => void; + serializedBody?: RequestInit['body']; + /** + * Default retry delay in milliseconds. + * + * This option applies only if the endpoint returns a stream of events. + * + * @default 3000 + */ + sseDefaultRetryDelay?: number; + /** + * Maximum number of retry attempts before giving up. + */ + sseMaxRetryAttempts?: number; + /** + * Maximum retry delay in milliseconds. + * + * Applies only when exponential backoff is used. + * + * This option applies only if the endpoint returns a stream of events. + * + * @default 30000 + */ + sseMaxRetryDelay?: number; + /** + * Optional sleep function for retry backoff. + * + * Defaults to using `setTimeout`. + */ + sseSleepFn?: (ms: number) => Promise; + url: string; + }; + +export interface StreamEvent { + data: TData; + event?: string; + id?: string; + retry?: number; +} + +export type ServerSentEventsResult = { + stream: AsyncGenerator< + TData extends Record ? TData[keyof TData] : TData, + TReturn, + TNext + >; +}; + +export function createSseClient({ + onRequest, + onSseError, + onSseEvent, + responseTransformer, + responseValidator, + sseDefaultRetryDelay, + sseMaxRetryAttempts, + sseMaxRetryDelay, + sseSleepFn, + url, + ...options +}: ServerSentEventsOptions): ServerSentEventsResult { + let lastEventId: string | undefined; + + const sleep = sseSleepFn ?? ((ms: number) => new Promise((resolve) => setTimeout(resolve, ms))); + + const createStream = async function* () { + let retryDelay: number = sseDefaultRetryDelay ?? 3000; + let attempt = 0; + const signal = options.signal ?? new AbortController().signal; + + while (true) { + if (signal.aborted) break; + + attempt++; + + const headers = + options.headers instanceof Headers + ? options.headers + : new Headers(options.headers as Record | undefined); + + if (lastEventId !== undefined) { + headers.set('Last-Event-ID', lastEventId); + } + + try { + const requestInit: RequestInit = { + redirect: 'follow', + ...options, + body: options.serializedBody, + headers, + signal, + }; + let request = new Request(url, requestInit); + if (onRequest) { + request = await onRequest(url, requestInit); + } + // fetch must be assigned here, otherwise it would throw the error: + // TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation + const _fetch = options.fetch ?? globalThis.fetch; + const response = await _fetch(request); + + if (!response.ok) throw new Error(`SSE failed: ${response.status} ${response.statusText}`); + + if (!response.body) throw new Error('No body in SSE response'); + + const reader = response.body.pipeThrough(new TextDecoderStream()).getReader(); + + let buffer = ''; + + const abortHandler = () => { + try { + reader.cancel(); + } catch { + // noop + } + }; + + signal.addEventListener('abort', abortHandler); + + try { + while (true) { + const { done, value } = await reader.read(); + if (done) break; + buffer += value; + buffer = buffer.replace(/\r\n?/g, '\n'); // normalize line endings + + const chunks = buffer.split('\n\n'); + buffer = chunks.pop() ?? ''; + + for (const chunk of chunks) { + const lines = chunk.split('\n'); + const dataLines: Array = []; + let eventName: string | undefined; + + for (const line of lines) { + if (line.startsWith('data:')) { + dataLines.push(line.replace(/^data:\s*/, '')); + } else if (line.startsWith('event:')) { + eventName = line.replace(/^event:\s*/, ''); + } else if (line.startsWith('id:')) { + lastEventId = line.replace(/^id:\s*/, ''); + } else if (line.startsWith('retry:')) { + const parsed = Number.parseInt(line.replace(/^retry:\s*/, ''), 10); + if (!Number.isNaN(parsed)) { + retryDelay = parsed; + } + } + } + + let data: unknown; + let parsedJson = false; + + if (dataLines.length) { + const rawData = dataLines.join('\n'); + try { + data = JSON.parse(rawData); + parsedJson = true; + } catch { + data = rawData; + } + } + + if (parsedJson) { + if (responseValidator) { + await responseValidator(data); + } + + if (responseTransformer) { + data = await responseTransformer(data); + } + } + + onSseEvent?.({ + data, + event: eventName, + id: lastEventId, + retry: retryDelay, + }); + + if (dataLines.length) { + yield data as any; + } + } + } + } finally { + signal.removeEventListener('abort', abortHandler); + reader.releaseLock(); + } + + break; // exit loop on normal completion + } catch (error) { + // connection failed or aborted; retry after delay + onSseError?.(error); + + if (sseMaxRetryAttempts !== undefined && attempt >= sseMaxRetryAttempts) { + break; // stop after firing error + } + + // exponential backoff: double retry each attempt, cap at 30s + const backoff = Math.min(retryDelay * 2 ** (attempt - 1), sseMaxRetryDelay ?? 30000); + await sleep(backoff); + } + } + }; + + const stream = createStream(); + + return { stream }; +} diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/types.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/types.gen.ts new file mode 100644 index 0000000000..9efe71d4c1 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/types.gen.ts @@ -0,0 +1,104 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import type { Auth, AuthToken } from './auth.gen'; +import type { BodySerializer, QuerySerializer, QuerySerializerOptions } from './bodySerializer.gen'; + +export type HttpMethod = + | 'connect' + | 'delete' + | 'get' + | 'head' + | 'options' + | 'patch' + | 'post' + | 'put' + | 'trace'; + +export type Client< + RequestFn = never, + Config = unknown, + MethodFn = never, + BuildUrlFn = never, + SseFn = never, +> = { + /** + * Returns the final request URL. + */ + buildUrl: BuildUrlFn; + getConfig: () => Config; + request: RequestFn; + setConfig: (config: Config) => Config; +} & { + [K in HttpMethod]: MethodFn; +} & ([SseFn] extends [never] ? { sse?: never } : { sse: { [K in HttpMethod]: SseFn } }); + +export interface Config { + /** + * Auth token or a function returning auth token. The resolved value will be + * added to the request payload as defined by its `security` array. + */ + auth?: ((auth: Auth) => Promise | AuthToken) | AuthToken; + /** + * A function for serializing request body parameter. By default, + * {@link JSON.stringify()} will be used. + */ + bodySerializer?: BodySerializer | null; + /** + * An object containing any HTTP headers that you want to pre-populate your + * `Headers` object with. + * + * {@link https://developer.mozilla.org/docs/Web/API/Headers/Headers#init See more} + */ + headers?: + | RequestInit['headers'] + | Record< + string, + string | number | boolean | (string | number | boolean)[] | null | undefined | unknown + >; + /** + * The request method. + * + * {@link https://developer.mozilla.org/docs/Web/API/fetch#method See more} + */ + method?: Uppercase; + /** + * A function for serializing request query parameters. By default, arrays + * will be exploded in form style, objects will be exploded in deepObject + * style, and reserved characters are percent-encoded. + * + * This method will have no effect if the native `paramsSerializer()` Axios + * API function is used. + * + * {@link https://swagger.io/docs/specification/serialization/#query View examples} + */ + querySerializer?: QuerySerializer | QuerySerializerOptions; + /** + * A function validating request data. This is useful if you want to ensure + * the request conforms to the desired shape, so it can be safely sent to + * the server. + */ + requestValidator?: (data: unknown) => Promise; + /** + * A function transforming response data before it's returned. This is useful + * for post-processing data, e.g., converting ISO strings into Date objects. + */ + responseTransformer?: (data: unknown) => Promise; + /** + * A function validating response data. This is useful if you want to ensure + * the response conforms to the desired shape, so it can be safely passed to + * the transformers and returned to the user. + */ + responseValidator?: (data: unknown) => Promise; +} + +type IsExactlyNeverOrNeverUndefined = [T] extends [never] + ? true + : [T] extends [never | undefined] + ? [undefined] extends [T] + ? false + : true + : false; + +export type OmitNever> = { + [K in keyof T as IsExactlyNeverOrNeverUndefined extends true ? never : K]: T[K]; +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/utils.gen.ts new file mode 100644 index 0000000000..9a4fec7830 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/core/utils.gen.ts @@ -0,0 +1,140 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import type { BodySerializer, QuerySerializer } from './bodySerializer.gen'; +import { + type ArraySeparatorStyle, + serializeArrayParam, + serializeObjectParam, + serializePrimitiveParam, +} from './pathSerializer.gen'; + +export interface PathSerializer { + path: Record; + url: string; +} + +export const PATH_PARAM_RE = /\{[^{}]+\}/g; + +export const defaultPathSerializer = ({ path, url: _url }: PathSerializer) => { + let url = _url; + const matches = _url.match(PATH_PARAM_RE); + if (matches) { + for (const match of matches) { + let explode = false; + let name = match.substring(1, match.length - 1); + let style: ArraySeparatorStyle = 'simple'; + + if (name.endsWith('*')) { + explode = true; + name = name.substring(0, name.length - 1); + } + + if (name.startsWith('.')) { + name = name.substring(1); + style = 'label'; + } else if (name.startsWith(';')) { + name = name.substring(1); + style = 'matrix'; + } + + const value = path[name]; + + if (value === undefined || value === null) { + continue; + } + + if (Array.isArray(value)) { + url = url.replace(match, serializeArrayParam({ explode, name, style, value })); + continue; + } + + if (typeof value === 'object') { + url = url.replace( + match, + serializeObjectParam({ + explode, + name, + style, + value: value as Record, + valueOnly: true, + }), + ); + continue; + } + + if (style === 'matrix') { + url = url.replace( + match, + `;${serializePrimitiveParam({ + name, + value: value as string, + })}`, + ); + continue; + } + + const replaceValue = encodeURIComponent( + style === 'label' ? `.${value as string}` : (value as string), + ); + url = url.replace(match, replaceValue); + } + } + return url; +}; + +export const getUrl = ({ + baseUrl, + path, + query, + querySerializer, + url: _url, +}: { + baseUrl?: string; + path?: Record; + query?: Record; + querySerializer: QuerySerializer; + url: string; +}) => { + const pathUrl = _url.startsWith('/') ? _url : `/${_url}`; + let url = (baseUrl ?? '') + pathUrl; + if (path) { + url = defaultPathSerializer({ path, url }); + } + let search = query ? querySerializer(query) : ''; + if (search.startsWith('?')) { + search = search.substring(1); + } + if (search) { + url += `?${search}`; + } + return url; +}; + +export function getValidRequestBody(options: { + body?: unknown; + bodySerializer?: BodySerializer | null; + serializedBody?: unknown; +}) { + const hasBody = options.body !== undefined; + const isSerializedBody = hasBody && options.bodySerializer; + + if (isSerializedBody) { + if ('serializedBody' in options) { + const hasSerializedBody = + options.serializedBody !== undefined && options.serializedBody !== ''; + + return hasSerializedBody ? options.serializedBody : null; + } + + // not all clients implement a serializedBody property (i.e., client-axios) + return options.body !== '' ? options.body : null; + } + + // plain/text body + if (hasBody) { + return options.body; + } + + // no body was provided + return undefined; +} diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/index.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/index.ts new file mode 100644 index 0000000000..b8bd9b3081 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/index.ts @@ -0,0 +1,4 @@ +// This file is auto-generated by @hey-api/openapi-ts + +export { getFoo, type Options } from './sdk.gen'; +export type { ClientOptions, GetFooData, GetFooResponse, GetFooResponses } from './types.gen'; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/sdk.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/sdk.gen.ts new file mode 100644 index 0000000000..ab5c4a2406 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/sdk.gen.ts @@ -0,0 +1,27 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import type { Client, Options as Options2, TDataShape } from './client'; +import { client } from './client.gen'; +import { getFooResponseTransformer } from './transformers.gen'; +import type { GetFooData, GetFooResponses } from './types.gen'; + +export type Options = Options2 & { + /** + * You can provide a client instance returned by `createClient()` instead of + * individual options. This might be also useful if you want to implement a + * custom client. + */ + client?: Client; + /** + * You can pass arbitrary values through the `meta` object. This can be + * used to access values that aren't defined as part of the SDK function. + */ + meta?: Record; +}; + +export const getFoo = (options: Options) => (options.client ?? client).get({ + querySerializer: { parameters: { stichdatum: { date: 'date' }, timestamp: { date: 'date-time' } } }, + responseTransformer: getFooResponseTransformer, + url: '/foo', + ...options +}); diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/transformers.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/transformers.gen.ts new file mode 100644 index 0000000000..4a42affacc --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/transformers.gen.ts @@ -0,0 +1,9 @@ +// This file is auto-generated by @hey-api/openapi-ts + +import type { GetFooResponse } from './types.gen'; + +export const getFooResponseTransformer = async (data: any): Promise => { + data.createdAt = new Date(data.createdAt); + data.validDate = new Date(data.validDate); + return data; +}; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/types.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/types.gen.ts new file mode 100644 index 0000000000..0c71bfb634 --- /dev/null +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-date-query-params/types.gen.ts @@ -0,0 +1,27 @@ +// This file is auto-generated by @hey-api/openapi-ts + +export type ClientOptions = { + baseUrl: `${string}://${string}` | (string & {}); +}; + +export type GetFooData = { + body?: never; + path?: never; + query: { + stichdatum: Date; + timestamp?: Date; + }; + url: '/foo'; +}; + +export type GetFooResponses = { + /** + * OK + */ + 200: { + createdAt: Date; + validDate: Date; + }; +}; + +export type GetFooResponse = GetFooResponses[keyof GetFooResponses]; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-one-of-discriminated/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transformers-recursive/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/client/utils.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/client/utils.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/main/test/__snapshots__/3.1.x/transforms-read-write/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-angular/bundle/utils.ts b/packages/openapi-ts/src/plugins/@hey-api/client-angular/bundle/utils.ts index 4b6a3c5c96..3670a0333b 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-angular/bundle/utils.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-angular/bundle/utils.ts @@ -106,7 +106,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-axios/bundle/utils.ts b/packages/openapi-ts/src/plugins/@hey-api/client-axios/bundle/utils.ts index 1fdde0367c..adddc48493 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-axios/bundle/utils.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-axios/bundle/utils.ts @@ -24,7 +24,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-core/bundle/bodySerializer.ts b/packages/openapi-ts/src/plugins/@hey-api/client-core/bundle/bodySerializer.ts index 00bd43929c..a7b199d644 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-core/bundle/bodySerializer.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-core/bundle/bodySerializer.ts @@ -7,6 +7,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-fetch/bundle/utils.ts b/packages/openapi-ts/src/plugins/@hey-api/client-fetch/bundle/utils.ts index e55d072237..59e555ae64 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-fetch/bundle/utils.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-fetch/bundle/utils.ts @@ -25,7 +25,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-ky/bundle/utils.ts b/packages/openapi-ts/src/plugins/@hey-api/client-ky/bundle/utils.ts index 3e2da15826..40b85ec0b0 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-ky/bundle/utils.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-ky/bundle/utils.ts @@ -25,7 +25,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-next/bundle/utils.ts b/packages/openapi-ts/src/plugins/@hey-api/client-next/bundle/utils.ts index 50ff580f74..915329db74 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-next/bundle/utils.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-next/bundle/utils.ts @@ -105,7 +105,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-nuxt/bundle/utils.ts b/packages/openapi-ts/src/plugins/@hey-api/client-nuxt/bundle/utils.ts index 34061c6160..2a1452684f 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-nuxt/bundle/utils.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-nuxt/bundle/utils.ts @@ -109,7 +109,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts/src/plugins/@hey-api/client-ofetch/bundle/utils.ts b/packages/openapi-ts/src/plugins/@hey-api/client-ofetch/bundle/utils.ts index 7d177454f6..73844d7ede 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/client-ofetch/bundle/utils.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/client-ofetch/bundle/utils.ts @@ -34,7 +34,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts b/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts index 3e54a36257..c9d5eab5c3 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts @@ -324,6 +324,14 @@ export function operationStatements({ ), ); } + } else if ( + parameter.schema.type === 'string' && + (parameter.schema.format === 'date' || parameter.schema.format === 'date-time') + ) { + paramSerializers.prop( + parameter.name, + $.object().prop('date', $.literal(parameter.schema.format)), + ); } } diff --git a/specs/3.1.x/transformers-date-query-params.json b/specs/3.1.x/transformers-date-query-params.json new file mode 100644 index 0000000000..17fdc66d96 --- /dev/null +++ b/specs/3.1.x/transformers-date-query-params.json @@ -0,0 +1,57 @@ +{ + "openapi": "3.1.0", + "info": { + "title": "OpenAPI 3.1.0 transformers date query params example", + "version": "1" + }, + "paths": { + "/foo": { + "get": { + "operationId": "getFoo", + "parameters": [ + { + "name": "stichdatum", + "in": "query", + "required": true, + "schema": { + "type": "string", + "format": "date" + } + }, + { + "name": "timestamp", + "in": "query", + "required": false, + "schema": { + "type": "string", + "format": "date-time" + } + } + ], + "responses": { + "200": { + "description": "OK", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "createdAt": { + "type": "string", + "format": "date-time" + }, + "validDate": { + "type": "string", + "format": "date" + } + }, + "required": ["createdAt", "validDate"] + } + } + } + } + } + } + } + } +} From 79aece3c79a9c764580758d70d3b53d4a1eb3bae Mon Sep 17 00:00:00 2001 From: Roland Weiss Date: Tue, 7 Apr 2026 15:52:10 +0200 Subject: [PATCH 2/4] chore: regenerate example client code --- .../src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-angular/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-axios/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-fastify/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-fetch/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + examples/openapi-ts-ky/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-nestjs/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-next/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-ofetch/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../openapi-ts-openai/src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + .../src/client/client/utils.gen.ts | 11 ++++++++++- .../src/client/core/bodySerializer.gen.ts | 1 + 30 files changed, 165 insertions(+), 15 deletions(-) diff --git a/examples/openapi-ts-angular-common/src/client/client/utils.gen.ts b/examples/openapi-ts-angular-common/src/client/client/utils.gen.ts index 7a8b555ecb..96ab240a92 100644 --- a/examples/openapi-ts-angular-common/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-angular-common/src/client/client/utils.gen.ts @@ -105,7 +105,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-angular-common/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-angular-common/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-angular-common/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-angular-common/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-angular/src/client/client/utils.gen.ts b/examples/openapi-ts-angular/src/client/client/utils.gen.ts index 7a8b555ecb..96ab240a92 100644 --- a/examples/openapi-ts-angular/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-angular/src/client/client/utils.gen.ts @@ -105,7 +105,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-angular/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-angular/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-angular/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-angular/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-axios/src/client/client/utils.gen.ts b/examples/openapi-ts-axios/src/client/client/utils.gen.ts index ee02336a33..423dee7592 100644 --- a/examples/openapi-ts-axios/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-axios/src/client/client/utils.gen.ts @@ -26,7 +26,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-axios/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-axios/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-axios/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-axios/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-fastify/src/client/client/utils.gen.ts b/examples/openapi-ts-fastify/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-fastify/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-fastify/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-fastify/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-fastify/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-fastify/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-fastify/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-fetch/src/client/client/utils.gen.ts b/examples/openapi-ts-fetch/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-fetch/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-fetch/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-fetch/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-fetch/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-fetch/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-fetch/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-ky/src/client/client/utils.gen.ts b/examples/openapi-ts-ky/src/client/client/utils.gen.ts index 4b3317888a..291cf76023 100644 --- a/examples/openapi-ts-ky/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-ky/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-ky/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-ky/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-ky/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-ky/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-nestjs/src/client/client/utils.gen.ts b/examples/openapi-ts-nestjs/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-nestjs/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-nestjs/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-nestjs/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-nestjs/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-nestjs/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-nestjs/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-next/src/client/client/utils.gen.ts b/examples/openapi-ts-next/src/client/client/utils.gen.ts index b993d6d84b..cf4a61b953 100644 --- a/examples/openapi-ts-next/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-next/src/client/client/utils.gen.ts @@ -104,7 +104,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-next/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-next/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-next/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-next/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-ofetch/src/client/client/utils.gen.ts b/examples/openapi-ts-ofetch/src/client/client/utils.gen.ts index 52e6a90723..8b22e2af79 100644 --- a/examples/openapi-ts-ofetch/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-ofetch/src/client/client/utils.gen.ts @@ -36,7 +36,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-ofetch/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-ofetch/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-ofetch/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-ofetch/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-openai/src/client/client/utils.gen.ts b/examples/openapi-ts-openai/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-openai/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-openai/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-openai/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-openai/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-openai/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-openai/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-pinia-colada/src/client/client/utils.gen.ts b/examples/openapi-ts-pinia-colada/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-pinia-colada/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-pinia-colada/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-pinia-colada/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-pinia-colada/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-pinia-colada/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-pinia-colada/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-tanstack-angular-query-experimental/src/client/client/utils.gen.ts b/examples/openapi-ts-tanstack-angular-query-experimental/src/client/client/utils.gen.ts index 7a8b555ecb..96ab240a92 100644 --- a/examples/openapi-ts-tanstack-angular-query-experimental/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-tanstack-angular-query-experimental/src/client/client/utils.gen.ts @@ -105,7 +105,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-tanstack-angular-query-experimental/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-tanstack-angular-query-experimental/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-tanstack-angular-query-experimental/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-tanstack-angular-query-experimental/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-tanstack-react-query/src/client/client/utils.gen.ts b/examples/openapi-ts-tanstack-react-query/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-tanstack-react-query/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-tanstack-react-query/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-tanstack-react-query/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-tanstack-react-query/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-tanstack-react-query/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-tanstack-react-query/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-tanstack-svelte-query/src/client/client/utils.gen.ts b/examples/openapi-ts-tanstack-svelte-query/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-tanstack-svelte-query/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-tanstack-svelte-query/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-tanstack-svelte-query/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-tanstack-svelte-query/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-tanstack-svelte-query/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-tanstack-svelte-query/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/examples/openapi-ts-tanstack-vue-query/src/client/client/utils.gen.ts b/examples/openapi-ts-tanstack-vue-query/src/client/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/examples/openapi-ts-tanstack-vue-query/src/client/client/utils.gen.ts +++ b/examples/openapi-ts-tanstack-vue-query/src/client/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/examples/openapi-ts-tanstack-vue-query/src/client/core/bodySerializer.gen.ts b/examples/openapi-ts-tanstack-vue-query/src/client/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/examples/openapi-ts-tanstack-vue-query/src/client/core/bodySerializer.gen.ts +++ b/examples/openapi-ts-tanstack-vue-query/src/client/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; From a52bfe420c0f1997e0a33a6122bb3e523fec4994 Mon Sep 17 00:00:00 2001 From: Roland Weiss Date: Tue, 7 Apr 2026 15:59:35 +0200 Subject: [PATCH 3/4] fix: gate date query serializer hints on transformers plugin Only emit per-parameter date format hints in querySerializer config when @hey-api/transformers is enabled with dates: true. Without the transformer, params are typed as string (not Date), so the instanceof Date check would never match at runtime. --- packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts b/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts index c9d5eab5c3..042642d9e9 100644 --- a/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts +++ b/packages/openapi-ts/src/plugins/@hey-api/sdk/shared/operation.ts @@ -325,6 +325,7 @@ export function operationStatements({ ); } } else if ( + plugin.getPlugin('@hey-api/transformers')?.config.dates && parameter.schema.type === 'string' && (parameter.schema.format === 'date' || parameter.schema.format === 'date-time') ) { From 22e4f07be06cb5b0a22c559077f364aea11b6b87 Mon Sep 17 00:00:00 2001 From: Roland Weiss Date: Tue, 7 Apr 2026 16:10:01 +0200 Subject: [PATCH 4/4] test(snapshots): update sdks, valibot, and zod snapshot files --- .../method-class-conflict/class/client/utils.gen.ts | 11 ++++++++++- .../class/core/bodySerializer.gen.ts | 1 + .../method-class-conflict/flat/client/utils.gen.ts | 11 ++++++++++- .../flat/core/bodySerializer.gen.ts | 1 + .../instance/client/utils.gen.ts | 11 ++++++++++- .../instance/core/bodySerializer.gen.ts | 1 + .../opencode/export-all/client/utils.gen.ts | 11 ++++++++++- .../opencode/export-all/core/bodySerializer.gen.ts | 1 + .../__snapshots__/opencode/flat/client/utils.gen.ts | 11 ++++++++++- .../opencode/flat/core/bodySerializer.gen.ts | 1 + .../opencode/grouped/client/utils.gen.ts | 11 ++++++++++- .../opencode/grouped/core/bodySerializer.gen.ts | 1 + .../3.1.x/type-format/client/utils.gen.ts | 11 ++++++++++- .../3.1.x/type-format/core/bodySerializer.gen.ts | 1 + .../2.0.x/mini/type-format/client/utils.gen.ts | 11 ++++++++++- .../2.0.x/mini/type-format/core/bodySerializer.gen.ts | 1 + .../2.0.x/v3/type-format/client/utils.gen.ts | 11 ++++++++++- .../2.0.x/v3/type-format/core/bodySerializer.gen.ts | 1 + .../2.0.x/v4/type-format/client/utils.gen.ts | 11 ++++++++++- .../2.0.x/v4/type-format/core/bodySerializer.gen.ts | 1 + .../3.0.x/mini/type-format/client/utils.gen.ts | 11 ++++++++++- .../3.0.x/mini/type-format/core/bodySerializer.gen.ts | 1 + .../3.0.x/v3/type-format/client/utils.gen.ts | 11 ++++++++++- .../3.0.x/v3/type-format/core/bodySerializer.gen.ts | 1 + .../3.0.x/v4/type-format/client/utils.gen.ts | 11 ++++++++++- .../3.0.x/v4/type-format/core/bodySerializer.gen.ts | 1 + .../3.1.x/mini/type-format/client/utils.gen.ts | 11 ++++++++++- .../3.1.x/mini/type-format/core/bodySerializer.gen.ts | 1 + .../3.1.x/v3/type-format/client/utils.gen.ts | 11 ++++++++++- .../3.1.x/v3/type-format/core/bodySerializer.gen.ts | 1 + .../3.1.x/v4/type-format/client/utils.gen.ts | 11 ++++++++++- .../3.1.x/v4/type-format/core/bodySerializer.gen.ts | 1 + 32 files changed, 176 insertions(+), 16 deletions(-) diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/client/utils.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/client/utils.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/class/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/client/utils.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/client/utils.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/flat/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/client/utils.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/client/utils.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/method-class-conflict/instance/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/client/utils.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/client/utils.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/export-all/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/client/utils.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/client/utils.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/flat/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/client/utils.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/client/utils.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/sdks/__snapshots__/opencode/grouped/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/valibot/v1/__snapshots__/3.1.x/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/mini/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v3/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/2.0.x/v4/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/mini/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v3/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.0.x/v4/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/mini/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v3/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; }; diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/client/utils.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/client/utils.gen.ts index 5162192d8a..32431a9f15 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/client/utils.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/client/utils.gen.ts @@ -27,7 +27,16 @@ export const createQuerySerializer = ({ const options = parameters[name] || args; - if (Array.isArray(value)) { + if (value instanceof Date) { + const dateValue = + options.date === 'date' ? value.toISOString().slice(0, 10) : value.toISOString(); + const serializedPrimitive = serializePrimitiveParam({ + allowReserved: options.allowReserved, + name, + value: dateValue, + }); + if (serializedPrimitive) search.push(serializedPrimitive); + } else if (Array.isArray(value)) { const serializedArray = serializeArrayParam({ allowReserved: options.allowReserved, explode: true, diff --git a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/core/bodySerializer.gen.ts b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/core/bodySerializer.gen.ts index 67daca60f8..dd36c4a3a3 100644 --- a/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/core/bodySerializer.gen.ts +++ b/packages/openapi-ts-tests/zod/v4/__snapshots__/3.1.x/v4/type-format/core/bodySerializer.gen.ts @@ -9,6 +9,7 @@ export type BodySerializer = (body: unknown) => unknown; type QuerySerializerOptionsObject = { allowReserved?: boolean; array?: Partial>; + date?: 'date' | 'date-time'; object?: Partial>; };