@kubb/plugin-client 3.0.0-alpha.2 → 3.0.0-alpha.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/README.md +13 -4
  2. package/client.ts +2 -2
  3. package/dist/chunk-54CFYFPX.js +176 -0
  4. package/dist/chunk-54CFYFPX.js.map +1 -0
  5. package/dist/chunk-HGQQGWKN.js +130 -0
  6. package/dist/chunk-HGQQGWKN.js.map +1 -0
  7. package/dist/chunk-HUIJQCWL.cjs +185 -0
  8. package/dist/chunk-HUIJQCWL.cjs.map +1 -0
  9. package/dist/chunk-NEK3OJBX.cjs +133 -0
  10. package/dist/chunk-NEK3OJBX.cjs.map +1 -0
  11. package/dist/client.cjs +16 -7
  12. package/dist/client.cjs.map +1 -1
  13. package/dist/client.d.cts +2 -2
  14. package/dist/client.d.ts +2 -2
  15. package/dist/client.js +5 -6
  16. package/dist/client.js.map +1 -1
  17. package/dist/components.cjs +11 -4
  18. package/dist/components.cjs.map +1 -1
  19. package/dist/components.d.cts +37 -7
  20. package/dist/components.d.ts +37 -7
  21. package/dist/components.js +2 -8
  22. package/dist/components.js.map +1 -1
  23. package/dist/generators.cjs +17 -0
  24. package/dist/generators.cjs.map +1 -0
  25. package/dist/generators.d.cts +9 -0
  26. package/dist/generators.d.ts +9 -0
  27. package/dist/generators.js +4 -0
  28. package/dist/generators.js.map +1 -0
  29. package/dist/index.cjs +11 -156
  30. package/dist/index.cjs.map +1 -1
  31. package/dist/index.d.cts +1 -6
  32. package/dist/index.d.ts +1 -6
  33. package/dist/index.js +3 -161
  34. package/dist/index.js.map +1 -1
  35. package/dist/types-xPfBu1CW.d.cts +96 -0
  36. package/dist/types-xPfBu1CW.d.ts +96 -0
  37. package/package.json +21 -16
  38. package/src/components/Client.tsx +110 -211
  39. package/src/components/Operations.tsx +9 -75
  40. package/src/generators/__snapshots__/deletePet.ts +13 -0
  41. package/src/generators/__snapshots__/deletePetObject.ts +15 -0
  42. package/src/generators/__snapshots__/findByTags.ts +13 -0
  43. package/src/generators/__snapshots__/findByTagsFull.ts +13 -0
  44. package/src/generators/__snapshots__/findByTagsWithZod.ts +13 -0
  45. package/src/generators/__snapshots__/findByTagsWithZodFull.ts +13 -0
  46. package/src/generators/__snapshots__/importPath.ts +13 -0
  47. package/src/generators/__snapshots__/operations.ts +82 -0
  48. package/src/generators/__snapshots__/updatePetById.ts +12 -0
  49. package/src/generators/clientGenerator.tsx +67 -0
  50. package/src/generators/index.ts +2 -0
  51. package/src/generators/operationsGenerator.tsx +26 -0
  52. package/src/plugin.ts +23 -40
  53. package/src/types.ts +24 -50
  54. package/dist/chunk-W57BRY5O.js +0 -201
  55. package/dist/chunk-W57BRY5O.js.map +0 -1
  56. package/dist/chunk-W7F5CMU6.cjs +0 -201
  57. package/dist/chunk-W7F5CMU6.cjs.map +0 -1
  58. package/dist/types-xK4X9e5d.d.cts +0 -228
  59. package/dist/types-xK4X9e5d.d.ts +0 -228
  60. package/src/OperationGenerator.tsx +0 -65
  61. package/src/components/__snapshots__/Client/showPetById.ts +0 -11
  62. package/src/components/__snapshots__/Operations/showPetById.ts +0 -6
  63. package/src/components/__snapshots__/Query/showPetById.ts +0 -15
@@ -0,0 +1,67 @@
1
+ import { createReactGenerator } from '@kubb/plugin-oas'
2
+ import { useOperationManager } from '@kubb/plugin-oas/hooks'
3
+ import { pluginTsName } from '@kubb/plugin-ts'
4
+ import { pluginZodName } from '@kubb/plugin-zod'
5
+ import { File, useApp } from '@kubb/react'
6
+ import { Client } from '../components/Client'
7
+ import type { PluginClient } from '../types'
8
+
9
+ export const clientGenerator = createReactGenerator<PluginClient>({
10
+ name: 'client',
11
+ Operation({ options, operation }) {
12
+ const {
13
+ plugin: {
14
+ options: { output },
15
+ },
16
+ } = useApp<PluginClient>()
17
+ const { getSchemas, getName, getFile } = useOperationManager()
18
+
19
+ const client = {
20
+ name: getName(operation, { type: 'function' }),
21
+ file: getFile(operation),
22
+ }
23
+
24
+ const type = {
25
+ file: getFile(operation, { pluginKey: [pluginTsName] }),
26
+ schemas: getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' }),
27
+ }
28
+
29
+ const zod = {
30
+ file: getFile(operation, { pluginKey: [pluginZodName] }),
31
+ schemas: getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' }),
32
+ }
33
+
34
+ return (
35
+ <File baseName={client.file.baseName} path={client.file.path} meta={client.file.meta} banner={output?.banner} footer={output?.footer}>
36
+ <File.Import name={'client'} path={options.importPath} />
37
+ <File.Import name={['RequestConfig']} path={options.importPath} isTypeOnly />
38
+ {options.parser === 'zod' && <File.Import extName={output?.extName} name={[zod.schemas.response.name]} root={client.file.path} path={zod.file.path} />}
39
+ <File.Import
40
+ extName={output?.extName}
41
+ name={[
42
+ type.schemas.request?.name,
43
+ type.schemas.response.name,
44
+ type.schemas.pathParams?.name,
45
+ type.schemas.queryParams?.name,
46
+ type.schemas.headerParams?.name,
47
+ ...(type.schemas.statusCodes?.map((item) => item.name) || []),
48
+ ].filter(Boolean)}
49
+ root={client.file.path}
50
+ path={type.file.path}
51
+ isTypeOnly
52
+ />
53
+
54
+ <Client
55
+ name={client.name}
56
+ baseURL={options.baseURL}
57
+ dataReturnType={options.dataReturnType}
58
+ pathParamsType={options.pathParamsType}
59
+ typeSchemas={type.schemas}
60
+ operation={operation}
61
+ parser={options.parser}
62
+ zodSchemas={zod.schemas}
63
+ />
64
+ </File>
65
+ )
66
+ },
67
+ })
@@ -0,0 +1,2 @@
1
+ export { clientGenerator } from './clientGenerator.tsx'
2
+ export { operationsGenerator } from './operationsGenerator.tsx'
@@ -0,0 +1,26 @@
1
+ import { pluginClientName } from '@kubb/plugin-client'
2
+ import { createReactGenerator } from '@kubb/plugin-oas'
3
+ import { File, useApp } from '@kubb/react'
4
+ import { Operations } from '../components/Operations'
5
+ import type { PluginClient } from '../types'
6
+
7
+ export const operationsGenerator = createReactGenerator<PluginClient>({
8
+ name: 'client',
9
+ Operations({ operations }) {
10
+ const {
11
+ pluginManager,
12
+ plugin: {
13
+ options: { output },
14
+ },
15
+ } = useApp<PluginClient>()
16
+
17
+ const name = 'operations'
18
+ const file = pluginManager.getFile({ name, extName: '.ts', pluginKey: [pluginClientName] })
19
+
20
+ return (
21
+ <File baseName={file.baseName} path={file.path} meta={file.meta} banner={output?.banner} footer={output?.footer}>
22
+ <Operations name={name} operations={operations} />
23
+ </File>
24
+ )
25
+ },
26
+ })
package/src/plugin.ts CHANGED
@@ -3,14 +3,13 @@ import path from 'node:path'
3
3
  import { FileManager, PluginManager, createPlugin } from '@kubb/core'
4
4
  import { camelCase } from '@kubb/core/transformers'
5
5
  import { renderTemplate } from '@kubb/core/utils'
6
- import { pluginOasName } from '@kubb/plugin-oas'
7
- import { getGroupedByTagFiles } from '@kubb/plugin-oas/utils'
8
-
9
- import { OperationGenerator } from './OperationGenerator.tsx'
10
- import { Client, Operations } from './components/index.ts'
6
+ import { OperationGenerator, pluginOasName } from '@kubb/plugin-oas'
11
7
 
12
8
  import type { Plugin } from '@kubb/core'
13
9
  import type { PluginOas as SwaggerPluginOptions } from '@kubb/plugin-oas'
10
+ import { pluginZodName } from '@kubb/plugin-zod'
11
+ import { operationsGenerator } from './generators'
12
+ import { clientGenerator } from './generators/clientGenerator.tsx'
14
13
  import type { PluginClient } from './types.ts'
15
14
 
16
15
  export const pluginClientName = 'plugin-client' satisfies PluginClient['name']
@@ -25,7 +24,9 @@ export const pluginClient = createPlugin<PluginClient>((options) => {
25
24
  transformers = {},
26
25
  dataReturnType = 'data',
27
26
  pathParamsType = 'inline',
28
- templates,
27
+ operations = false,
28
+ importPath = '@kubb/plugin-client/client',
29
+ parser = 'client',
29
30
  } = options
30
31
 
31
32
  const template = group?.output ? group.output : `${output.path}/{{tag}}Controller`
@@ -33,21 +34,17 @@ export const pluginClient = createPlugin<PluginClient>((options) => {
33
34
  return {
34
35
  name: pluginClientName,
35
36
  options: {
36
- extName: output.extName,
37
- dataReturnType,
38
- client: {
39
- importPath: '@kubb/plugin-client/client',
40
- ...options.client,
37
+ output: {
38
+ exportType: 'barrelNamed',
39
+ ...output,
41
40
  },
41
+ parser,
42
+ dataReturnType,
43
+ importPath,
42
44
  pathParamsType,
43
- templates: {
44
- operations: Operations.templates,
45
- client: Client.templates,
46
- ...templates,
47
- },
48
45
  baseURL: undefined,
49
46
  },
50
- pre: [pluginOasName],
47
+ pre: [pluginOasName, parser === 'zod' ? pluginZodName : undefined].filter(Boolean),
51
48
  resolvePath(baseName, pathMode, options) {
52
49
  const root = path.resolve(this.config.root, this.config.output.path)
53
50
  const mode = pathMode ?? FileManager.getMode(path.resolve(root, output.path))
@@ -102,37 +99,23 @@ export const pluginClient = createPlugin<PluginClient>((options) => {
102
99
  },
103
100
  )
104
101
 
105
- const files = await operationGenerator.build()
102
+ const files = await operationGenerator.build(...[clientGenerator, operations ? operationsGenerator : undefined].filter(Boolean))
106
103
 
107
104
  await this.addFile(...files)
108
- },
109
- async buildEnd() {
110
- if (this.config.output.write === false) {
111
- return
112
- }
113
-
114
- const root = path.resolve(this.config.root, this.config.output.path)
115
105
 
116
- if (group?.type === 'tag') {
117
- const rootFiles = await getGroupedByTagFiles({
118
- logger: this.logger,
119
- files: this.fileManager.files,
120
- plugin: this.plugin,
121
- template,
122
- exportAs: group.exportAs || '{{tag}}Service',
106
+ if (this.config.output.exportType) {
107
+ const barrelFiles = await this.fileManager.getBarrelFiles({
123
108
  root,
124
109
  output,
110
+ files: this.fileManager.files,
111
+ meta: {
112
+ pluginKey: this.plugin.key,
113
+ },
114
+ logger: this.logger,
125
115
  })
126
116
 
127
- await this.addFile(...rootFiles)
117
+ await this.addFile(...barrelFiles)
128
118
  }
129
-
130
- await this.fileManager.addIndexes({
131
- root,
132
- output,
133
- meta: { pluginKey: this.plugin.key },
134
- logger: this.logger,
135
- })
136
119
  },
137
120
  }
138
121
  })
package/src/types.ts CHANGED
@@ -1,35 +1,9 @@
1
- import type { Plugin, PluginFactoryOptions, ResolveNameParams } from '@kubb/core'
2
- import type * as KubbFile from '@kubb/fs/types'
1
+ import type { Output, PluginFactoryOptions, ResolveNameParams } from '@kubb/core'
3
2
 
4
3
  import type { Exclude, Include, Override, ResolvePathOptions } from '@kubb/plugin-oas'
5
- import type { Client, Operations } from './components/index.ts'
6
-
7
- type Templates = {
8
- operations?: typeof Operations.templates | false
9
- client?: typeof Client.templates | false
10
- }
11
4
 
12
5
  export type Options = {
13
- output?: {
14
- /**
15
- * Output to save the clients.
16
- * @default `"clients"``
17
- */
18
- path: string
19
- /**
20
- * Name to be used for the `export * as {{exportAs}} from './'`
21
- */
22
- exportAs?: string
23
- /**
24
- * Add an extension to the generated imports and exports, default it will not use an extension
25
- */
26
- extName?: KubbFile.Extname
27
- /**
28
- * Define what needs to exported, here you can also disable the export of barrel files
29
- * @default `'barrel'`
30
- */
31
- exportType?: 'barrel' | 'barrelNamed' | false
32
- }
6
+ output?: Output
33
7
  /**
34
8
  * Group the clients based on the provided name.
35
9
  */
@@ -64,16 +38,19 @@ export type Options = {
64
38
  * Array containing override parameters to override `options` based on tags/operations/methods/paths.
65
39
  */
66
40
  override?: Array<Override<ResolvedOptions>>
67
- client?: {
68
- /**
69
- * Path to the client import path that will be used to do the API calls.
70
- * It will be used as `import client from '${client.importPath}'`.
71
- * It allows both relative and absolute path.
72
- * the path will be applied as is, so relative path should be based on the file being generated.
73
- * @default '@kubb/plugin-client/client'
74
- */
75
- importPath?: string
76
- }
41
+ /**
42
+ * Create `operations.ts` file with all operations grouped by methods.
43
+ * @default `false`
44
+ */
45
+ operations?: boolean
46
+ /**
47
+ * Path to the client import path that will be used to do the API calls.
48
+ * It will be used as `import client from '${client.importPath}'`.
49
+ * It allows both relative and absolute path.
50
+ * the path will be applied as is, so relative path should be based on the file being generated.
51
+ * @default '@kubb/plugin-client/client'
52
+ */
53
+ importPath?: string
77
54
  /**
78
55
  * ReturnType that needs to be used when calling client().
79
56
  *
@@ -94,30 +71,27 @@ export type Options = {
94
71
  * @private
95
72
  */
96
73
  pathParamsType?: 'object' | 'inline'
74
+ /**
75
+ * Which parser can be used before returning the data
76
+ * `'zod'` will use `@kubb/plugin-zod` to parse the data.
77
+ * @default 'client'
78
+ */
79
+ parser?: 'client' | 'zod'
97
80
  transformers?: {
98
81
  /**
99
82
  * Customize the names based on the type that is provided by the plugin.
100
83
  */
101
84
  name?: (name: ResolveNameParams['name'], type?: ResolveNameParams['type']) => string
102
85
  }
103
- /**
104
- * Make it possible to override one of the templates
105
- */
106
- templates?: Partial<Templates>
107
86
  }
108
87
 
109
88
  type ResolvedOptions = {
110
- extName: KubbFile.Extname | undefined
89
+ output: Output
111
90
  baseURL: string | undefined
112
- client: Required<NonNullable<Options['client']>>
91
+ parser: NonNullable<Options['parser']>
92
+ importPath: NonNullable<Options['importPath']>
113
93
  dataReturnType: NonNullable<Options['dataReturnType']>
114
94
  pathParamsType: NonNullable<Options['pathParamsType']>
115
- templates: NonNullable<Templates>
116
- }
117
-
118
- export type FileMeta = {
119
- pluginKey?: Plugin['key']
120
- tag?: string
121
95
  }
122
96
 
123
97
  export type PluginClient = PluginFactoryOptions<'plugin-client', Options, ResolvedOptions, never, ResolvePathOptions>
@@ -1,201 +0,0 @@
1
- // src/components/Client.tsx
2
- import { URLPath } from "@kubb/core/utils";
3
- import { Parser, File, Function, useApp } from "@kubb/react";
4
- import { pluginTsName } from "@kubb/plugin-ts";
5
- import { useOperation, useOperationManager } from "@kubb/plugin-oas/hooks";
6
- import { getComments, getPathParams } from "@kubb/plugin-oas/utils";
7
- import { isOptional } from "@kubb/oas";
8
- import { jsx, jsxs } from "@kubb/react/jsx-runtime";
9
- function Template({ name, generics, returnType, params, JSDoc, client }) {
10
- const isFormData = client.contentType === "multipart/form-data";
11
- const headers = [
12
- client.contentType !== "application/json" ? `'Content-Type': '${client.contentType}'` : void 0,
13
- client.withHeaders ? "...headers" : void 0
14
- ].filter(Boolean).join(", ");
15
- const clientParams = {
16
- data: {
17
- mode: "object",
18
- children: {
19
- method: {
20
- type: "string",
21
- value: JSON.stringify(client.method)
22
- },
23
- url: {
24
- type: "string",
25
- value: client.path.template
26
- },
27
- baseURL: client.baseURL ? {
28
- type: "string",
29
- value: JSON.stringify(client.baseURL)
30
- } : void 0,
31
- params: client.withQueryParams ? {
32
- type: "any"
33
- } : void 0,
34
- data: client.withData ? {
35
- type: "any",
36
- value: isFormData ? "formData" : void 0
37
- } : void 0,
38
- headers: headers.length ? {
39
- type: "any",
40
- value: headers.length ? `{ ${headers}, ...options.headers }` : void 0
41
- } : void 0,
42
- options: {
43
- type: "any",
44
- mode: "inlineSpread"
45
- }
46
- }
47
- }
48
- };
49
- const formData = isFormData ? `
50
- const formData = new FormData()
51
- if(data) {
52
- Object.keys(data).forEach((key) => {
53
- const value = data[key];
54
- if (typeof key === "string" && (typeof value === "string" || value instanceof Blob)) {
55
- formData.append(key, value);
56
- }
57
- })
58
- }
59
- ` : void 0;
60
- return /* @__PURE__ */ jsxs(Function, { name, async: true, export: true, generics, returnType, params, JSDoc, children: [
61
- formData || "",
62
- /* @__PURE__ */ jsx(Function.Call, { name: "res", to: /* @__PURE__ */ jsx(Function, { name: "client", async: true, generics: client.generics, params: clientParams }) }),
63
- /* @__PURE__ */ jsx(Function.Return, { children: client.dataReturnType === "data" ? "res.data" : "res" })
64
- ] });
65
- }
66
- function RootTemplate({ children }) {
67
- const {
68
- plugin: {
69
- options: {
70
- client: { importPath },
71
- extName
72
- }
73
- }
74
- } = useApp();
75
- const { getSchemas, getFile } = useOperationManager();
76
- const operation = useOperation();
77
- const file = getFile(operation);
78
- const fileType = getFile(operation, { pluginKey: [pluginTsName] });
79
- const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: "type" });
80
- return /* @__PURE__ */ jsx(Parser, { language: "typescript", children: /* @__PURE__ */ jsxs(File, { baseName: file.baseName, path: file.path, meta: file.meta, children: [
81
- /* @__PURE__ */ jsx(File.Import, { name: "client", path: importPath }),
82
- /* @__PURE__ */ jsx(File.Import, { name: ["ResponseConfig"], path: importPath, isTypeOnly: true }),
83
- /* @__PURE__ */ jsx(
84
- File.Import,
85
- {
86
- extName,
87
- name: [schemas.request?.name, schemas.response.name, schemas.pathParams?.name, schemas.queryParams?.name, schemas.headerParams?.name].filter(Boolean),
88
- root: file.path,
89
- path: fileType.path,
90
- isTypeOnly: true
91
- }
92
- ),
93
- /* @__PURE__ */ jsx(File.Source, { children })
94
- ] }) });
95
- }
96
- var defaultTemplates = { default: Template, root: RootTemplate };
97
- function Client({ baseURL, Template: Template3 = defaultTemplates.default }) {
98
- const {
99
- plugin: {
100
- options: { client, dataReturnType, pathParamsType }
101
- }
102
- } = useApp();
103
- const { getSchemas, getName } = useOperationManager();
104
- const operation = useOperation();
105
- const contentType = operation.getContentType();
106
- const name = getName(operation, { type: "function" });
107
- const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: "type" });
108
- return /* @__PURE__ */ jsx(
109
- Template3,
110
- {
111
- name,
112
- params: {
113
- pathParams: {
114
- mode: pathParamsType === "object" ? "object" : "inlineSpread",
115
- children: getPathParams(schemas.pathParams, { typed: true })
116
- },
117
- data: schemas.request?.name ? {
118
- type: schemas.request?.name,
119
- optional: isOptional(schemas.request?.schema)
120
- } : void 0,
121
- params: schemas.queryParams?.name ? {
122
- type: schemas.queryParams?.name,
123
- optional: isOptional(schemas.queryParams?.schema)
124
- } : void 0,
125
- headers: schemas.headerParams?.name ? {
126
- type: schemas.headerParams?.name,
127
- optional: isOptional(schemas.headerParams?.schema)
128
- } : void 0,
129
- options: {
130
- type: "Partial<Parameters<typeof client>[0]>",
131
- default: "{}"
132
- }
133
- },
134
- returnType: dataReturnType === "data" ? `ResponseConfig<${schemas.response.name}>["data"]` : `ResponseConfig<${schemas.response.name}>`,
135
- JSDoc: {
136
- comments: getComments(operation)
137
- },
138
- client: {
139
- // only set baseURL from serverIndex(swagger) when no custom client(default) is used
140
- baseURL: client.importPath === "@kubb/plugin-client/client" ? baseURL : void 0,
141
- generics: [schemas.response.name, schemas.request?.name].filter(Boolean),
142
- dataReturnType,
143
- withQueryParams: !!schemas.queryParams?.name,
144
- withData: !!schemas.request?.name,
145
- withHeaders: !!schemas.headerParams?.name,
146
- method: operation.method,
147
- path: new URLPath(operation.path),
148
- contentType
149
- }
150
- }
151
- );
152
- }
153
- Client.File = function({ baseURL, ...props }) {
154
- const templates = { ...defaultTemplates, ...props.templates };
155
- const Template3 = templates.default;
156
- const RootTemplate3 = templates.root;
157
- return /* @__PURE__ */ jsx(RootTemplate3, { children: /* @__PURE__ */ jsx(Client, { baseURL, Template: Template3 }) });
158
- };
159
- Client.templates = defaultTemplates;
160
-
161
- // src/components/Operations.tsx
162
- import { URLPath as URLPath2 } from "@kubb/core/utils";
163
- import { useOperations } from "@kubb/plugin-oas/hooks";
164
- import { Const, File as File2, Parser as Parser2, useApp as useApp2 } from "@kubb/react";
165
- import { jsx as jsx2 } from "@kubb/react/jsx-runtime";
166
- function Template2({ name, operations }) {
167
- const operationsObject = {};
168
- operations.forEach((operation) => {
169
- operationsObject[operation.getOperationId()] = {
170
- path: new URLPath2(operation.path).URL,
171
- method: operation.method
172
- };
173
- });
174
- return /* @__PURE__ */ jsx2(Const, { name, export: true, asConst: true, children: JSON.stringify(operationsObject, void 0, 2) });
175
- }
176
- function RootTemplate2({ children }) {
177
- const {
178
- pluginManager,
179
- plugin: { key: pluginKey }
180
- } = useApp2();
181
- const file = pluginManager.getFile({ name: "operations", extName: ".ts", pluginKey });
182
- return /* @__PURE__ */ jsx2(Parser2, { language: "typescript", children: /* @__PURE__ */ jsx2(File2, { baseName: file.baseName, path: file.path, meta: file.meta, exportable: false, children: /* @__PURE__ */ jsx2(File2.Source, { children }) }) });
183
- }
184
- var defaultTemplates2 = { default: Template2, root: RootTemplate2 };
185
- function Operations({ baseURL, Template: Template3 = defaultTemplates2.default }) {
186
- const operations = useOperations();
187
- return /* @__PURE__ */ jsx2(Template3, { baseURL, name: "operations", operations });
188
- }
189
- Operations.File = function({ baseURL, ...props }) {
190
- const templates = { ...defaultTemplates2, ...props.templates };
191
- const Template3 = templates.default;
192
- const RootTemplate3 = templates.root;
193
- return /* @__PURE__ */ jsx2(RootTemplate3, { children: /* @__PURE__ */ jsx2(Operations, { baseURL, Template: Template3 }) });
194
- };
195
- Operations.templates = defaultTemplates2;
196
-
197
- export {
198
- Client,
199
- Operations
200
- };
201
- //# sourceMappingURL=chunk-W57BRY5O.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/Client.tsx","../src/components/Operations.tsx"],"sourcesContent":["import { URLPath } from '@kubb/core/utils'\nimport { Parser, File, Function, useApp } from '@kubb/react'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getComments, getPathParams } from '@kubb/plugin-oas/utils'\n\nimport { isOptional } from '@kubb/oas'\nimport type { HttpMethod } from '@kubb/oas'\nimport type { KubbNode, Params } from '@kubb/react'\nimport type { ComponentProps, ComponentType } from 'react'\nimport type { FileMeta, PluginClient } from '../types.ts'\n\ntype TemplateProps = {\n /**\n * Name of the function\n */\n name: string\n /**\n * Parameters/options/props that need to be used\n */\n params: Params\n /**\n * Generics that needs to be added for TypeScript\n */\n generics?: string\n /**\n * ReturnType(see async for adding Promise type)\n */\n returnType?: string\n /**\n * Options for JSdocs\n */\n JSDoc?: {\n comments: string[]\n }\n client: {\n baseURL: string | undefined\n generics: string | string[]\n method: HttpMethod\n path: URLPath\n dataReturnType: PluginClient['options']['dataReturnType']\n withQueryParams: boolean\n withData: boolean\n withHeaders: boolean\n contentType: string\n }\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, client }: TemplateProps): KubbNode {\n const isFormData = client.contentType === 'multipart/form-data'\n const headers = [\n client.contentType !== 'application/json' ? `'Content-Type': '${client.contentType}'` : undefined,\n client.withHeaders ? '...headers' : undefined,\n ]\n .filter(Boolean)\n .join(', ')\n const clientParams: Params = {\n data: {\n mode: 'object',\n children: {\n method: {\n type: 'string',\n value: JSON.stringify(client.method),\n },\n url: {\n type: 'string',\n value: client.path.template,\n },\n baseURL: client.baseURL\n ? {\n type: 'string',\n value: JSON.stringify(client.baseURL),\n }\n : undefined,\n params: client.withQueryParams\n ? {\n type: 'any',\n }\n : undefined,\n data: client.withData\n ? {\n type: 'any',\n value: isFormData ? 'formData' : undefined,\n }\n : undefined,\n headers: headers.length\n ? {\n type: 'any',\n value: headers.length ? `{ ${headers}, ...options.headers }` : undefined,\n }\n : undefined,\n options: {\n type: 'any',\n mode: 'inlineSpread',\n },\n },\n },\n }\n\n const formData = isFormData\n ? `\n const formData = new FormData()\n if(data) {\n Object.keys(data).forEach((key) => {\n const value = data[key];\n if (typeof key === \"string\" && (typeof value === \"string\" || value instanceof Blob)) {\n formData.append(key, value);\n }\n })\n }\n `\n : undefined\n\n return (\n <Function name={name} async export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {formData || ''}\n <Function.Call name=\"res\" to={<Function name=\"client\" async generics={client.generics} params={clientParams} />} />\n <Function.Return>{client.dataReturnType === 'data' ? 'res.data' : 'res'}</Function.Return>\n </Function>\n )\n}\n\ntype RootTemplateProps = {\n children?: React.ReactNode\n}\n\nfunction RootTemplate({ children }: RootTemplateProps) {\n const {\n plugin: {\n options: {\n client: { importPath },\n extName,\n },\n },\n } = useApp<PluginClient>()\n\n const { getSchemas, getFile } = useOperationManager()\n const operation = useOperation()\n\n const file = getFile(operation)\n const fileType = getFile(operation, { pluginKey: [pluginTsName] })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n return (\n <Parser language=\"typescript\">\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n <File.Import name={'client'} path={importPath} />\n <File.Import name={['ResponseConfig']} path={importPath} isTypeOnly />\n <File.Import\n extName={extName}\n name={[schemas.request?.name, schemas.response.name, schemas.pathParams?.name, schemas.queryParams?.name, schemas.headerParams?.name].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n <File.Source>{children}</File.Source>\n </File>\n </Parser>\n )\n}\n\nconst defaultTemplates = { default: Template, root: RootTemplate } as const\n\ntype Templates = Partial<typeof defaultTemplates>\n\ntype ClientProps = {\n baseURL: string | undefined\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: ComponentType<ComponentProps<typeof Template>>\n}\n\nexport function Client({ baseURL, Template = defaultTemplates.default }: ClientProps): KubbNode {\n const {\n plugin: {\n options: { client, dataReturnType, pathParamsType },\n },\n } = useApp<PluginClient>()\n\n const { getSchemas, getName } = useOperationManager()\n const operation = useOperation()\n\n const contentType = operation.getContentType()\n const name = getName(operation, { type: 'function' })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n return (\n <Template\n name={name}\n params={{\n pathParams: {\n mode: pathParamsType === 'object' ? 'object' : 'inlineSpread',\n children: getPathParams(schemas.pathParams, { typed: true }),\n },\n data: schemas.request?.name\n ? {\n type: schemas.request?.name,\n optional: isOptional(schemas.request?.schema),\n }\n : undefined,\n params: schemas.queryParams?.name\n ? {\n type: schemas.queryParams?.name,\n optional: isOptional(schemas.queryParams?.schema),\n }\n : undefined,\n headers: schemas.headerParams?.name\n ? {\n type: schemas.headerParams?.name,\n optional: isOptional(schemas.headerParams?.schema),\n }\n : undefined,\n options: {\n type: 'Partial<Parameters<typeof client>[0]>',\n default: '{}',\n },\n }}\n returnType={dataReturnType === 'data' ? `ResponseConfig<${schemas.response.name}>[\"data\"]` : `ResponseConfig<${schemas.response.name}>`}\n JSDoc={{\n comments: getComments(operation),\n }}\n client={{\n // only set baseURL from serverIndex(swagger) when no custom client(default) is used\n baseURL: client.importPath === '@kubb/plugin-client/client' ? baseURL : undefined,\n generics: [schemas.response.name, schemas.request?.name].filter(Boolean),\n dataReturnType,\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withHeaders: !!schemas.headerParams?.name,\n method: operation.method,\n path: new URLPath(operation.path),\n contentType,\n }}\n />\n )\n}\n\ntype FileProps = {\n baseURL: string | undefined\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: Templates\n}\n\nClient.File = function ({ baseURL, ...props }: FileProps): KubbNode {\n const templates = { ...defaultTemplates, ...props.templates }\n\n const Template = templates.default\n const RootTemplate = templates.root\n\n return (\n <RootTemplate>\n <Client baseURL={baseURL} Template={Template} />\n </RootTemplate>\n )\n}\n\nClient.templates = defaultTemplates\n","import { URLPath } from '@kubb/core/utils'\nimport { useOperations } from '@kubb/plugin-oas/hooks'\nimport { Const, File, Parser, useApp } from '@kubb/react'\n\nimport type { HttpMethod, Operation } from '@kubb/oas'\nimport type { KubbNode } from '@kubb/react'\nimport type { ComponentProps, ComponentType } from 'react'\nimport type { FileMeta, PluginClient } from '../types.ts'\n\ntype TemplateProps = {\n /**\n * Name of the function\n */\n name: string\n operations: Operation[]\n baseURL: string | undefined\n}\n\nfunction Template({ name, operations }: TemplateProps): KubbNode {\n const operationsObject: Record<string, { path: string; method: HttpMethod }> = {}\n\n operations.forEach((operation) => {\n operationsObject[operation.getOperationId()] = {\n path: new URLPath(operation.path).URL,\n method: operation.method,\n }\n })\n return (\n <Const name={name} export asConst>\n {JSON.stringify(operationsObject, undefined, 2)}\n </Const>\n )\n}\n\ntype RootTemplateProps = {\n children?: React.ReactNode\n}\n\nfunction RootTemplate({ children }: RootTemplateProps) {\n const {\n pluginManager,\n plugin: { key: pluginKey },\n } = useApp<PluginClient>()\n const file = pluginManager.getFile({ name: 'operations', extName: '.ts', pluginKey })\n\n return (\n <Parser language=\"typescript\">\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta} exportable={false}>\n <File.Source>{children}</File.Source>\n </File>\n </Parser>\n )\n}\n\nconst defaultTemplates = { default: Template, root: RootTemplate } as const\n\ntype Templates = Partial<typeof defaultTemplates>\n\ntype Props = {\n baseURL: string | undefined\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: ComponentType<ComponentProps<typeof Template>>\n}\n\nexport function Operations({ baseURL, Template = defaultTemplates.default }: Props): KubbNode {\n const operations = useOperations()\n\n return <Template baseURL={baseURL} name=\"operations\" operations={operations} />\n}\n\ntype FileProps = {\n baseURL: string | undefined\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: Templates\n}\n\nOperations.File = function ({ baseURL, ...props }: FileProps): KubbNode {\n const templates = { ...defaultTemplates, ...props.templates }\n\n const Template = templates.default\n const RootTemplate = templates.root\n\n return (\n <RootTemplate>\n <Operations baseURL={baseURL} Template={Template} />\n </RootTemplate>\n )\n}\n\nOperations.templates = defaultTemplates\n"],"mappings":"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","names":["Template","RootTemplate","URLPath","File","Parser","useApp","jsx","Template","RootTemplate","defaultTemplates"]}