@kubb/plugin-client 3.0.0-alpha.2 → 3.0.0-alpha.21
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.
- package/README.md +13 -4
- package/client.ts +2 -2
- package/dist/chunk-54CFYFPX.js +176 -0
- package/dist/chunk-54CFYFPX.js.map +1 -0
- package/dist/chunk-HGQQGWKN.js +130 -0
- package/dist/chunk-HGQQGWKN.js.map +1 -0
- package/dist/chunk-HUIJQCWL.cjs +185 -0
- package/dist/chunk-HUIJQCWL.cjs.map +1 -0
- package/dist/chunk-NEK3OJBX.cjs +133 -0
- package/dist/chunk-NEK3OJBX.cjs.map +1 -0
- package/dist/client.cjs +16 -7
- package/dist/client.cjs.map +1 -1
- package/dist/client.d.cts +2 -2
- package/dist/client.d.ts +2 -2
- package/dist/client.js +5 -6
- package/dist/client.js.map +1 -1
- package/dist/components.cjs +11 -4
- package/dist/components.cjs.map +1 -1
- package/dist/components.d.cts +37 -7
- package/dist/components.d.ts +37 -7
- package/dist/components.js +2 -8
- package/dist/components.js.map +1 -1
- package/dist/generators.cjs +17 -0
- package/dist/generators.cjs.map +1 -0
- package/dist/generators.d.cts +9 -0
- package/dist/generators.d.ts +9 -0
- package/dist/generators.js +4 -0
- package/dist/generators.js.map +1 -0
- package/dist/index.cjs +11 -156
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +1 -6
- package/dist/index.d.ts +1 -6
- package/dist/index.js +3 -161
- package/dist/index.js.map +1 -1
- package/dist/types-xPfBu1CW.d.cts +96 -0
- package/dist/types-xPfBu1CW.d.ts +96 -0
- package/package.json +22 -17
- package/src/components/Client.tsx +110 -211
- package/src/components/Operations.tsx +9 -75
- package/src/generators/__snapshots__/deletePet.ts +13 -0
- package/src/generators/__snapshots__/deletePetObject.ts +15 -0
- package/src/generators/__snapshots__/findByTags.ts +13 -0
- package/src/generators/__snapshots__/findByTagsFull.ts +13 -0
- package/src/generators/__snapshots__/findByTagsWithZod.ts +13 -0
- package/src/generators/__snapshots__/findByTagsWithZodFull.ts +13 -0
- package/src/generators/__snapshots__/importPath.ts +13 -0
- package/src/generators/__snapshots__/operations.ts +82 -0
- package/src/generators/__snapshots__/updatePetById.ts +12 -0
- package/src/generators/clientGenerator.tsx +67 -0
- package/src/generators/index.ts +2 -0
- package/src/generators/operationsGenerator.tsx +26 -0
- package/src/plugin.ts +23 -40
- package/src/types.ts +24 -50
- package/dist/chunk-W57BRY5O.js +0 -201
- package/dist/chunk-W57BRY5O.js.map +0 -1
- package/dist/chunk-W7F5CMU6.cjs +0 -201
- package/dist/chunk-W7F5CMU6.cjs.map +0 -1
- package/dist/types-xK4X9e5d.d.cts +0 -228
- package/dist/types-xK4X9e5d.d.ts +0 -228
- package/src/OperationGenerator.tsx +0 -65
- package/src/components/__snapshots__/Client/showPetById.ts +0 -11
- package/src/components/__snapshots__/Operations/showPetById.ts +0 -6
- 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,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
|
-
|
|
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
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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 (
|
|
117
|
-
const
|
|
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(...
|
|
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 {
|
|
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
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
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
|
-
|
|
89
|
+
output: Output
|
|
111
90
|
baseURL: string | undefined
|
|
112
|
-
|
|
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>
|
package/dist/chunk-W57BRY5O.js
DELETED
|
@@ -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":";AAAA,SAAS,eAAe;AACxB,SAAS,QAAQ,MAAM,UAAU,cAAc;AAC/C,SAAS,oBAAoB;AAC7B,SAAS,cAAc,2BAA2B;AAClD,SAAS,aAAa,qBAAqB;AAE3C,SAAS,kBAAkB;AA4GvB,SAEgC,KAFhC;AAlEJ,SAAS,SAAS,EAAE,MAAM,UAAU,YAAY,QAAQ,OAAO,OAAO,GAA4B;AAChG,QAAM,aAAa,OAAO,gBAAgB;AAC1C,QAAM,UAAU;AAAA,IACd,OAAO,gBAAgB,qBAAqB,oBAAoB,OAAO,WAAW,MAAM;AAAA,IACxF,OAAO,cAAc,eAAe;AAAA,EACtC,EACG,OAAO,OAAO,EACd,KAAK,IAAI;AACZ,QAAM,eAAuB;AAAA,IAC3B,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,UAAU;AAAA,QACR,QAAQ;AAAA,UACN,MAAM;AAAA,UACN,OAAO,KAAK,UAAU,OAAO,MAAM;AAAA,QACrC;AAAA,QACA,KAAK;AAAA,UACH,MAAM;AAAA,UACN,OAAO,OAAO,KAAK;AAAA,QACrB;AAAA,QACA,SAAS,OAAO,UACZ;AAAA,UACE,MAAM;AAAA,UACN,OAAO,KAAK,UAAU,OAAO,OAAO;AAAA,QACtC,IACA;AAAA,QACJ,QAAQ,OAAO,kBACX;AAAA,UACE,MAAM;AAAA,QACR,IACA;AAAA,QACJ,MAAM,OAAO,WACT;AAAA,UACE,MAAM;AAAA,UACN,OAAO,aAAa,aAAa;AAAA,QACnC,IACA;AAAA,QACJ,SAAS,QAAQ,SACb;AAAA,UACE,MAAM;AAAA,UACN,OAAO,QAAQ,SAAS,KAAK,OAAO,2BAA2B;AAAA,QACjE,IACA;AAAA,QACJ,SAAS;AAAA,UACP,MAAM;AAAA,UACN,MAAM;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,QAAM,WAAW,aACb;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAWA;AAEJ,SACE,qBAAC,YAAS,MAAY,OAAK,MAAC,QAAM,MAAC,UAAoB,YAAwB,QAAgB,OAC5F;AAAA,gBAAY;AAAA,IACb,oBAAC,SAAS,MAAT,EAAc,MAAK,OAAM,IAAI,oBAAC,YAAS,MAAK,UAAS,OAAK,MAAC,UAAU,OAAO,UAAU,QAAQ,cAAc,GAAI;AAAA,IACjH,oBAAC,SAAS,QAAT,EAAiB,iBAAO,mBAAmB,SAAS,aAAa,OAAM;AAAA,KAC1E;AAEJ;AAMA,SAAS,aAAa,EAAE,SAAS,GAAsB;AACrD,QAAM;AAAA,IACJ,QAAQ;AAAA,MACN,SAAS;AAAA,QACP,QAAQ,EAAE,WAAW;AAAA,QACrB;AAAA,MACF;AAAA,IACF;AAAA,EACF,IAAI,OAAqB;AAEzB,QAAM,EAAE,YAAY,QAAQ,IAAI,oBAAoB;AACpD,QAAM,YAAY,aAAa;AAE/B,QAAM,OAAO,QAAQ,SAAS;AAC9B,QAAM,WAAW,QAAQ,WAAW,EAAE,WAAW,CAAC,YAAY,EAAE,CAAC;AACjE,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAAC,YAAY,GAAG,MAAM,OAAO,CAAC;AAEjF,SACE,oBAAC,UAAO,UAAS,cACf,+BAAC,QAAe,UAAU,KAAK,UAAU,MAAM,KAAK,MAAM,MAAM,KAAK,MACnE;AAAA,wBAAC,KAAK,QAAL,EAAY,MAAM,UAAU,MAAM,YAAY;AAAA,IAC/C,oBAAC,KAAK,QAAL,EAAY,MAAM,CAAC,gBAAgB,GAAG,MAAM,YAAY,YAAU,MAAC;AAAA,IACpE;AAAA,MAAC,KAAK;AAAA,MAAL;AAAA,QACC;AAAA,QACA,MAAM,CAAC,QAAQ,SAAS,MAAM,QAAQ,SAAS,MAAM,QAAQ,YAAY,MAAM,QAAQ,aAAa,MAAM,QAAQ,cAAc,IAAI,EAAE,OAAO,OAAO;AAAA,QACpJ,MAAM,KAAK;AAAA,QACX,MAAM,SAAS;AAAA,QACf,YAAU;AAAA;AAAA,IACZ;AAAA,IACA,oBAAC,KAAK,QAAL,EAAa,UAAS;AAAA,KACzB,GACF;AAEJ;AAEA,IAAM,mBAAmB,EAAE,SAAS,UAAU,MAAM,aAAa;AAY1D,SAAS,OAAO,EAAE,SAAS,UAAAA,YAAW,iBAAiB,QAAQ,GAA0B;AAC9F,QAAM;AAAA,IACJ,QAAQ;AAAA,MACN,SAAS,EAAE,QAAQ,gBAAgB,eAAe;AAAA,IACpD;AAAA,EACF,IAAI,OAAqB;AAEzB,QAAM,EAAE,YAAY,QAAQ,IAAI,oBAAoB;AACpD,QAAM,YAAY,aAAa;AAE/B,QAAM,cAAc,UAAU,eAAe;AAC7C,QAAM,OAAO,QAAQ,WAAW,EAAE,MAAM,WAAW,CAAC;AACpD,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAAC,YAAY,GAAG,MAAM,OAAO,CAAC;AAEjF,SACE;AAAA,IAACA;AAAA,IAAA;AAAA,MACC;AAAA,MACA,QAAQ;AAAA,QACN,YAAY;AAAA,UACV,MAAM,mBAAmB,WAAW,WAAW;AAAA,UAC/C,UAAU,cAAc,QAAQ,YAAY,EAAE,OAAO,KAAK,CAAC;AAAA,QAC7D;AAAA,QACA,MAAM,QAAQ,SAAS,OACnB;AAAA,UACE,MAAM,QAAQ,SAAS;AAAA,UACvB,UAAU,WAAW,QAAQ,SAAS,MAAM;AAAA,QAC9C,IACA;AAAA,QACJ,QAAQ,QAAQ,aAAa,OACzB;AAAA,UACE,MAAM,QAAQ,aAAa;AAAA,UAC3B,UAAU,WAAW,QAAQ,aAAa,MAAM;AAAA,QAClD,IACA;AAAA,QACJ,SAAS,QAAQ,cAAc,OAC3B;AAAA,UACE,MAAM,QAAQ,cAAc;AAAA,UAC5B,UAAU,WAAW,QAAQ,cAAc,MAAM;AAAA,QACnD,IACA;AAAA,QACJ,SAAS;AAAA,UACP,MAAM;AAAA,UACN,SAAS;AAAA,QACX;AAAA,MACF;AAAA,MACA,YAAY,mBAAmB,SAAS,kBAAkB,QAAQ,SAAS,IAAI,cAAc,kBAAkB,QAAQ,SAAS,IAAI;AAAA,MACpI,OAAO;AAAA,QACL,UAAU,YAAY,SAAS;AAAA,MACjC;AAAA,MACA,QAAQ;AAAA;AAAA,QAEN,SAAS,OAAO,eAAe,+BAA+B,UAAU;AAAA,QACxE,UAAU,CAAC,QAAQ,SAAS,MAAM,QAAQ,SAAS,IAAI,EAAE,OAAO,OAAO;AAAA,QACvE;AAAA,QACA,iBAAiB,CAAC,CAAC,QAAQ,aAAa;AAAA,QACxC,UAAU,CAAC,CAAC,QAAQ,SAAS;AAAA,QAC7B,aAAa,CAAC,CAAC,QAAQ,cAAc;AAAA,QACrC,QAAQ,UAAU;AAAA,QAClB,MAAM,IAAI,QAAQ,UAAU,IAAI;AAAA,QAChC;AAAA,MACF;AAAA;AAAA,EACF;AAEJ;AAUA,OAAO,OAAO,SAAU,EAAE,SAAS,GAAG,MAAM,GAAwB;AAClE,QAAM,YAAY,EAAE,GAAG,kBAAkB,GAAG,MAAM,UAAU;AAE5D,QAAMA,YAAW,UAAU;AAC3B,QAAMC,gBAAe,UAAU;AAE/B,SACE,oBAACA,eAAA,EACC,8BAAC,UAAO,SAAkB,UAAUD,WAAU,GAChD;AAEJ;AAEA,OAAO,YAAY;;;ACnQnB,SAAS,WAAAE,gBAAe;AACxB,SAAS,qBAAqB;AAC9B,SAAS,OAAO,QAAAC,OAAM,UAAAC,SAAQ,UAAAC,eAAc;AA0BxC,gBAAAC,YAAA;AAVJ,SAASC,UAAS,EAAE,MAAM,WAAW,GAA4B;AAC/D,QAAM,mBAAyE,CAAC;AAEhF,aAAW,QAAQ,CAAC,cAAc;AAChC,qBAAiB,UAAU,eAAe,CAAC,IAAI;AAAA,MAC7C,MAAM,IAAIL,SAAQ,UAAU,IAAI,EAAE;AAAA,MAClC,QAAQ,UAAU;AAAA,IACpB;AAAA,EACF,CAAC;AACD,SACE,gBAAAI,KAAC,SAAM,MAAY,QAAM,MAAC,SAAO,MAC9B,eAAK,UAAU,kBAAkB,QAAW,CAAC,GAChD;AAEJ;AAMA,SAASE,cAAa,EAAE,SAAS,GAAsB;AACrD,QAAM;AAAA,IACJ;AAAA,IACA,QAAQ,EAAE,KAAK,UAAU;AAAA,EAC3B,IAAIH,QAAqB;AACzB,QAAM,OAAO,cAAc,QAAQ,EAAE,MAAM,cAAc,SAAS,OAAO,UAAU,CAAC;AAEpF,SACE,gBAAAC,KAACF,SAAA,EAAO,UAAS,cACf,0BAAAE,KAACH,OAAA,EAAe,UAAU,KAAK,UAAU,MAAM,KAAK,MAAM,MAAM,KAAK,MAAM,YAAY,OACrF,0BAAAG,KAACH,MAAK,QAAL,EAAa,UAAS,GACzB,GACF;AAEJ;AAEA,IAAMM,oBAAmB,EAAE,SAASF,WAAU,MAAMC,cAAa;AAY1D,SAAS,WAAW,EAAE,SAAS,UAAAD,YAAWE,kBAAiB,QAAQ,GAAoB;AAC5F,QAAM,aAAa,cAAc;AAEjC,SAAO,gBAAAH,KAACC,WAAA,EAAS,SAAkB,MAAK,cAAa,YAAwB;AAC/E;AAUA,WAAW,OAAO,SAAU,EAAE,SAAS,GAAG,MAAM,GAAwB;AACtE,QAAM,YAAY,EAAE,GAAGE,mBAAkB,GAAG,MAAM,UAAU;AAE5D,QAAMF,YAAW,UAAU;AAC3B,QAAMC,gBAAe,UAAU;AAE/B,SACE,gBAAAF,KAACE,eAAA,EACC,0BAAAF,KAAC,cAAW,SAAkB,UAAUC,WAAU,GACpD;AAEJ;AAEA,WAAW,YAAYE;","names":["Template","RootTemplate","URLPath","File","Parser","useApp","jsx","Template","RootTemplate","defaultTemplates"]}
|