@kubb/plugin-react-query 3.0.0-alpha.7 → 3.0.0-alpha.9

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.
@@ -83,7 +83,7 @@ ${_transformers2.default.createIndent(4)}`)}`;
83
83
  })
84
84
  }
85
85
  ` : void 0;
86
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { export: true, name, params, JSDoc, children: `
86
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { export: true, name, params, JSDoc, children: `
87
87
  const { mutation: mutationOptions, client: clientOptions = {} } = options ?? {}
88
88
 
89
89
  return ${hook.name}({
@@ -519,8 +519,8 @@ QueryImports.templates = defaultTemplates2;
519
519
 
520
520
  function Template3({ name, typeName, params, generics, returnType, JSDoc, keys }) {
521
521
  return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
522
- /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function.Arrow, { name, export: true, generics, params, returnType, singleLine: true, JSDoc, children: `[${keys}] as const` }) }),
523
- /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name: typeName, isExportable: true, isTypeOnly: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Type, { name: typeName, export: true, children: `ReturnType<typeof ${name}>` }) })
522
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function.Arrow, { name, export: true, generics, params, returnType, singleLine: true, JSDoc, children: `[${keys}] as const` }) }),
523
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name: typeName, isExportable: true, isIndexable: true, isTypeOnly: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Type, { name: typeName, export: true, children: `ReturnType<typeof ${name}>` }) })
524
524
  ] });
525
525
  }
526
526
  var defaultTemplates3 = {
@@ -697,7 +697,7 @@ ${_transformers2.default.createIndent(4)}`)}`;
697
697
  ` : void 0;
698
698
  if (infinite) {
699
699
  if (isV5) {
700
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, params, JSDoc, children: `
700
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, params, JSDoc, children: `
701
701
  const queryKey = ${hook.queryKey}
702
702
 
703
703
  return infiniteQueryOptions({
@@ -716,7 +716,7 @@ ${_transformers2.default.createIndent(4)}`)}`;
716
716
 
717
717
  ` }) });
718
718
  }
719
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
719
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
720
720
  const queryKey = ${hook.queryKey}
721
721
 
722
722
  return {
@@ -736,7 +736,7 @@ ${_transformers2.default.createIndent(4)}`)}`;
736
736
  ` }) });
737
737
  }
738
738
  if (isV5) {
739
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, params, JSDoc, children: `
739
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, params, JSDoc, children: `
740
740
  const queryKey = ${hook.queryKey}
741
741
 
742
742
  return queryOptions({
@@ -755,7 +755,7 @@ ${_transformers2.default.createIndent(4)}`)}`;
755
755
 
756
756
  ` }) });
757
757
  }
758
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
758
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
759
759
  const queryKey = ${hook.queryKey}
760
760
 
761
761
  return {
@@ -994,7 +994,7 @@ function Template5({ name, generics, returnType, params, JSDoc, hook, infinite }
994
994
  const isV5 = new (0, _core.PackageManager)().isValidSync(reactQueryDepRegex, ">=5");
995
995
  const resolvedReturnType = `${returnType} & { queryKey: TQueryKey }`;
996
996
  if (isV5) {
997
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
997
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
998
998
  const { query: queryOptions, client: clientOptions = {} } = options ?? {}
999
999
  const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}
1000
1000
 
@@ -1010,7 +1010,7 @@ function Template5({ name, generics, returnType, params, JSDoc, hook, infinite }
1010
1010
 
1011
1011
  ` }) });
1012
1012
  }
1013
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
1013
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
1014
1014
  const { query: queryOptions, client: clientOptions = {} } = options ?? {}
1015
1015
  const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}
1016
1016
 
@@ -1467,4 +1467,4 @@ Query.templates = defaultTemplates5;
1467
1467
 
1468
1468
 
1469
1469
  exports.Mutation = Mutation; exports.QueryImports = QueryImports; exports.QueryKey = QueryKey; exports.QueryOptions = QueryOptions; exports.Query = Query;
1470
- //# sourceMappingURL=chunk-ARFQ4UBW.cjs.map
1470
+ //# sourceMappingURL=chunk-7ZODZVKP.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/kubb/kubb/packages/plugin-react-query/dist/chunk-7ZODZVKP.cjs","../src/components/Mutation.tsx","../src/components/SchemaType.tsx","../src/components/Query.tsx","../src/utils.ts","../src/components/QueryImports.tsx","../src/components/QueryKey.tsx","../src/components/QueryOptions.tsx"],"names":["Fragment","useOperation","jsx","Template","RootTemplate","transformers","File","defaultTemplates","getASTParams","isRequired","URLPath","FunctionParams","Function","PackageManager","pluginZodName"],"mappings":"AAAA;ACAA,mHAAyB;AACzB,yCAAwC;AACxC,+CAAkD;AAClD,gDAA0C;AAC1C,oCAAuC;AACvC,2CAA6B;ADE7B;AACA;AERA;AACA;AAIA;AA4BI,qDAAA;AA1BG,SAAS,UAAA,CAAA,EAAwB;AACtC,EAAA,MAAM;AAAA,IACJ,MAAA,EAAQ;AAAA,MACN,OAAA,EAAS,EAAE,eAAe;AAAA,IAC5B;AAAA,EACF,EAAA,EAAI,2BAAA,CAAyB;AAC7B,EAAA,MAAM,EAAE,UAAA,EAAY,QAAQ,EAAA,EAAI,wCAAA,CAAoB;AACpD,EAAA,MAAM,UAAA,EAAY,iCAAA,CAAa;AAE/B,EAAA,MAAM,QAAA,EAAU,UAAA,CAAW,SAAA,EAAW,EAAE,SAAA,EAAW,CAAC,sBAAY,CAAA,EAAG,IAAA,EAAM,OAAO,CAAC,CAAA;AAEjF,EAAA,MAAM,CAAC,KAAA,EAAO,MAAA,EAAQ,QAAA,EAAU,WAAA,EAAa,YAAA,EAAc,aAAA,EAAe,SAAS,EAAA,EAAI;AAAA,IACrF,OAAA,CAAQ,QAAA,CAAS,IAAA;AAAA,oBACjB,OAAA,mBAAQ,MAAA,6BAAQ,GAAA,mBAAI,CAAC,IAAA,EAAA,GAAS,IAAA,CAAK,IAAI,CAAA,qBAAE,IAAA,mBAAK,KAAK,IAAA,GAAK,OAAA;AAAA,oBACxD,OAAA,qBAAQ,OAAA,6BAAS,OAAA,GAAQ,OAAA;AAAA,oBACzB,OAAA,qBAAQ,UAAA,6BAAY,OAAA,GAAQ,OAAA;AAAA,oBAC5B,OAAA,uBAAQ,WAAA,+BAAa,OAAA,GAAQ,OAAA;AAAA,oBAC7B,OAAA,uBAAQ,YAAA,+BAAc,OAAA,GAAQ,OAAA;AAAA,IAC9B,OAAA,CAAQ,QAAA,CAAS;AAAA,EACnB,CAAA;AACA,EAAA,MAAM,YAAA,EAAc,OAAA,CAAQ,SAAA,EAAW,EAAE,IAAA,EAAM,OAAO,CAAC,CAAA;AAEvD,EAAA,MAAM,WAAA,EAAa,CAAA,EAAA;AACA,EAAA;AAGjB,EAAA;AACE,oBAAA;AAGA,oBAAA;AAEK;AAEO,gBAAA;AACC,iBAAA;AACE,mBAAA;AAAkC,sBAAA;AACpB,uBAAA;AACE,wBAAA;AAEf,oBAAA;AAAwE;AAAA,2CAAA;AAEvC,uCAAA;AACJ;AAAA;AAK7C,QAAA;AACF,EAAA;AAEJ;AFLsB;AACA;AC7Cb;AAwSLA;AAjQgB;AACC,EAAA;AACH,EAAA;AACP,IAAA;AACA,IAAA;AAGN,EAAA;AAEG,EAAA;AACQ,IAAA;AACG,IAAA;AACR,IAAA;AACA,IAAA;AACA,IAAA;AACU,IAAA;AACjB,IAAA;AACc,EAAA;AAEV,EAAA;AAAgG;AAErF,EAAA;AACb;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,EAAA;AAGF,EAAA;AAEK;AAAA;AAGS,gBAAA;AAAS,6BAAA;AAEP,aAAA;AACL,aAAA;AAAc,sCAAA;AAEb,cAAA;AAAqB;AAAA;AAGf,oBAAA;AAA8C;AAAA;AAKhE,WAAA;AAEJ;AAMsB;AACd,EAAA;AACI,IAAA;AACG,MAAA;AACG,QAAA;AACV,QAAA;AACF,MAAA;AACF,IAAA;AAC2B,EAAA;AAET,EAAA;AACFC,EAAAA;AAEF,EAAA;AACH,EAAA;AACI,EAAA;AAGf,EAAA;AACEC,oBAAAA;AACAA,oBAAAA;AACAA,oBAAAA;AAAM,MAAA;AAAL,MAAA;AACO,QAAA;AACI,0BAAA;AACA,UAAA;AACA,0BAAA;AACA,0BAAA;AACA,0BAAA;AACI,UAAA;AACL,QAAA;AACE,QAAA;AACL,QAAA;AACI,QAAA;AAAA,MAAA;AACZ,IAAA;AACAA,oBAAAA;AAAM,MAAA;AAAL,MAAA;AACQ,QAAA;AACM,QAAA;AACH,QAAA;AAAA,MAAA;AACZ,IAAA;AACAA,oBAAAA;AACC,IAAA;AACH,EAAA;AAEJ;AAEM;AAWqB;AAGnB,EAAA;AACI,IAAA;AACK,MAAA;AACb,IAAA;AAC2B,EAAA;AAEXD,EAAAA;AACE,EAAA;AAEP,EAAA;AACG,EAAA;AACI,EAAA;AAED,EAAA;AACb,EAAA;AACc,EAAA;AAGlB,EAAA;AAEsB,IAAA;AAChB,IAAA;AACQ,MAAA;AACG,MAAA;AACE,MAAA;AACD,MAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACE,MAAA;AACD,MAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACE,MAAA;AACD,MAAA;AACZ,IAAA;AAEM,EAAA;AAIC,EAAA;AACK,IAAA;AACA,IAAA;AACJ,IAAA;AACI,IAAA;AACN,IAAA;AACM,IAAA;AACH,IAAA;AACf,IAAA;AACF,EAAA;AACa,EAAA;AACL,IAAA;AACQ,IAAA;AAChB,EAAA;AAEM,EAAA;AACU,IAAA;AACA,IAAA;AACI,IAAA;AACpB,EAAA;AAEc,EAAA;AACD,IAAA;AACT,MAAA;AACQ,QAAA;AACA,QAAA;AAAA,oCAAA;AAEG,eAAA;AAAW,GAAA;AAEX,QAAA;AACX,MAAA;AACD,IAAA;AAEgB,IAAA;AACf,MAAA;AACK,QAAA;AACH,QAAA;AACQ,UAAA;AACG,UAAA;AACC,UAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACG,UAAA;AACC,UAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACK,UAAA;AACD,UAAA;AACZ,QAAA;AACF,MAAA;AACD,IAAA;AACI,EAAA;AACM,IAAA;AACO,MAAA;AAChB,MAAA;AACQ,QAAA;AACG,QAAA;AACA,QAAA;AACC,QAAA;AACZ,MAAA;AACA,MAAA;AACQ,QAAA;AACG,QAAA;AACA,QAAA;AACC,QAAA;AACZ,MAAA;AACA,MAAA;AACQ,QAAA;AACA,QAAA;AAAA,oCAAA;AAEG,eAAA;AAAW,GAAA;AAEX,QAAA;AACX,MAAA;AACD,IAAA;AAEgB,IAAA;AACf,MAAA;AACQ,QAAA;AACK,QAAA;AACD,QAAA;AACZ,MAAA;AACD,IAAA;AACH,EAAA;AAEa,EAAA;AACJ,IAAA;AACT,EAAA;AAGE,EAAA;AACGE,IAAAA;AAAA,IAAA;AACC,MAAA;AACS,MAAA;AACT,MAAA;AACA,MAAA;AACe,MAAA;AACD,MAAA;AACd,MAAA;AAAA,IAAA;AAEJ,EAAA;AAEJ;AASgB;AACM,EAAA;AAEH,EAAA;AACXC,EAAAA;AAGJ,EAAA;AACEF,oBAAAA;AACAA,oBAAAA;AACF,EAAA;AAEJ;AAEqB;ADlDC;AACA;AGnSb;AACFG;AACE;AACAC;AACA;AACA;AACA;AACA;AHqSa;AACA;AI7Sb;AAEI;AAEG;AACG,EAAA;AAEV,EAAA;AACK,IAAA;AACD,MAAA;AACC,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACO,MAAA;AACC,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACQ,MAAA;AACA,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACK,MAAA;AACG,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACF,IAAA;AACO,IAAA;AACE,MAAA;AACC,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACO,MAAA;AACC,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACQ,MAAA;AACA,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACK,MAAA;AACG,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACF,IAAA;AACe,IAAA;AACN,MAAA;AACC,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACO,MAAA;AACC,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACQ,MAAA;AACA,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACK,MAAA;AACG,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACF,IAAA;AACe,IAAA;AACN,MAAA;AACC,QAAA;AACI,QAAA;AACG,QAAA;AACD,QAAA;AACd,MAAA;AACF,IAAA;AACF,EAAA;AACF;AJ4SsB;AACA;AK5Yb;AACAA;AAyBLN;AAFgB;AAEhB,EAAA;AACEE,oBAAAA;AACAA,oBAAAA;AAEiB,IAAA;AACjBA,oBAAAA;AACF,EAAA;AAEJ;AASMK;AACQ,EAAA;AACS,IAAA;AACX,MAAA;AACO,MAAA;AACL,MAAA;AAGN,MAAA;AAACJ,QAAAA;AAAA,QAAA;AACC,UAAA;AACK,UAAA;AACL,UAAA;AACA,UAAA;AACI,UAAA;AAAA,QAAA;AACN,MAAA;AAEJ,IAAA;AACF,EAAA;AACY,EAAA;AACS,IAAA;AACX,MAAA;AACO,MAAA;AACL,MAAA;AAGN,MAAA;AAACA,QAAAA;AAAA,QAAA;AACC,UAAA;AACK,UAAA;AACL,UAAA;AACA,UAAA;AACI,UAAA;AAAA,QAAA;AACN,MAAA;AAEJ,IAAA;AACF,EAAA;AACa,EAAA;AACQ,IAAA;AACX,MAAA;AACO,MAAA;AACL,MAAA;AAGN,MAAA;AAACA,QAAAA;AAAA,QAAA;AACC,UAAA;AACK,UAAA;AACL,UAAA;AACA,UAAA;AACI,UAAA;AAAA,QAAA;AACN,MAAA;AAEJ,IAAA;AACF,EAAA;AACU,EAAA;AACW,IAAA;AACX,MAAA;AACO,MAAA;AACL,MAAA;AACK,MAAA;AAGX,MAAA;AAEI,QAAA;AACE,0BAAA;AAACA,YAAAA;AAAA,YAAA;AACC,cAAA;AACK,cAAA;AACL,cAAA;AACA,cAAA;AACI,cAAA;AAAA,YAAA;AACN,UAAA;AACA,0BAAA;AACF,QAAA;AAGQ,QAAA;AAEN,0BAAA;AACA,0BAAA;AACA,0BAAA;AACF,QAAA;AAGS,QAAA;AAEP,0BAAA;AACA,0BAAA;AACA,0BAAA;AACF,QAAA;AAEF,wBAAA;AACA,wBAAA;AACA,wBAAA;AACF,MAAA;AAEJ,IAAA;AACF,EAAA;AACF;AAe6B;AAEzB,EAAA;AAACA,IAAAA;AAAA,IAAA;AACC,MAAA;AACS,MAAA;AACP,QAAA;AACA,QAAA;AACF,MAAA;AAAA,IAAA;AACF,EAAA;AAEJ;AAEa;ALwVS;AACA;AM/fb;AACA;AACA;AACAG;AAEA;AACA;AAoCLN;AAFgB;AAEhB,EAAA;AACEE,oBAAAA;AAMAA,oBAAAA;AAKF,EAAA;AAEJ;AAUMK;AACQ,EAAA;AACO,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACY,EAAA;AACO,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACa,EAAA;AACM,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACU,EAAA;AACW,IAAA;AACD,MAAA;AAEV,MAAA;AACI,QAAA;AACK,UAAA;AACb,QAAA;AAC2B,MAAA;AACrB,MAAA;AACF,MAAA;AAEU,MAAA;AACH,MAAA;AACE,MAAA;AACT,MAAA;AACA,MAAA;AAEK,MAAA;AACL,QAAA;AAEEC,UAAAA;AACS,YAAA;AACG,YAAA;AACL,cAAA;AACG,cAAA;AACR,YAAA;AACD,UAAA;AAEHA,QAAAA;AACS,UAAA;AACI,UAAA;AACN,YAAA;AACG,YAAA;AACR,UAAA;AACD,QAAA;AACL,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCC,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACD,MAAA;AAEY,MAAA;AACG,QAAA;AACN,UAAA;AACK,UAAA;AACA,UAAA;AACZ,QAAA;AACD,QAAA;AACc,QAAA;AACA,MAAA;AAET,MAAA;AACT,IAAA;AACF,EAAA;AACF;AAe2B;AACnB,EAAA;AACI,IAAA;AACK,MAAA;AACb,IAAA;AAC2B,EAAA;AACV,EAAA;AACDR,EAAAA;AAEF,EAAA;AACCS,EAAAA;AACEC,EAAAA;AACb,EAAA;AACc,EAAA;AAET,EAAA;AACL,IAAA;AACJ,IAAA;AACQ,MAAA;AACG,MAAA;AACA,MAAA;AACCF,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACA,MAAA;AACCA,MAAAA;AACZ,IAAA;AACD,EAAA;AAEY,EAAA;AACG,IAAA;AACN,MAAA;AACK,MAAA;AACZ,IAAA;AACiB,IAAA;AACJ,IAAA;AACA,EAAA;AAET,EAAA;AACT;AAEqBF;ANkbC;AACA;AO9nBb;AACFF;AACE;AACA;AACA;AACAO;AACA;AAEA;AAIA;AAkHCV;AArEU;AACDW,EAAAA;AACE,EAAA;AACH,EAAA;AACP,IAAA;AACA,IAAA;AAGN,EAAA;AAEG,EAAA;AACQ,IAAA;AACG,IAAA;AACR,IAAA;AACA,IAAA;AACA,IAAA;AACU,IAAA;AACjB,IAAA;AACO,IAAA;AACH;AAEW,QAAA;AAAU;AAGrB,KAAA;AACU,EAAA;AAEV,EAAA;AACM,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AAGA,IAAA;AAGA,IAAA;AAGI,EAAA;AAEV,EAAA;AAAgG;AAChG,EAAA;AAA8F;AAEpF,EAAA;AAEZ,EAAA;AACU,IAAA;AACd,EAAA;AAEiB,EAAA;AACb;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,EAAA;AAEU,EAAA;AACF,IAAA;AAEN,MAAA;AAEK,wBAAA;AAC0B;AAAA;AAAA;AAAA;AAKtB,UAAA;AACL,UAAA;AAAc,oCAAA;AAEZ,YAAA;AAAqB;AAAA;AAGb,WAAA;AAAA;AAEX,SAAA;AAAoB;AAAA;AAKvB,OAAA;AAEJ,IAAA;AAGE,IAAA;AAEK,0BAAA;AAC8B;AAAA;AAAA;AAAA;AAKrB,aAAA;AACL,aAAA;AAAc,sCAAA;AAEb,cAAA;AAAqB;AAAA;AAGtB,aAAA;AAAS;AAEX,WAAA;AAAoB;AAAA;AAK3B,SAAA;AAEJ,EAAA;AAEU,EAAA;AAEN,IAAA;AAGgB,oBAAA;AAAa;AAAA;AAAA;AAAA;AAKrB,OAAA;AACO,OAAA;AAAE,gCAAA;AAEb,QAAA;AAAqB;AAAA;AAGb,OAAA;AAAA;AAEX,KAAA;AAAoB;AAAA;AAKrB,GAAA;AAEJ,EAAA;AAGE,EAAA;AAEK,wBAAA;AAC8B;AAAA;AAAA;AAAA;AAKrB,WAAA;AACL,WAAA;AAAc,oCAAA;AAEb,YAAA;AAAqB;AAAA;AAGb,WAAA;AAAA;AAEX,SAAA;AAAoB;AAAA;AAK3B,OAAA;AAEJ;AAWMN;AACQ,EAAA;AACO,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACY,EAAA;AACO,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACa,EAAA;AACM,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACU,EAAA;AACW,IAAA;AACT,MAAA;AAEF,MAAA;AACI,QAAA;AACK,UAAA;AACb,QAAA;AAC2B,MAAA;AAErB,MAAA;AACF,MAAA;AAEU,MAAA;AACD,MAAA;AACT,MAAA;AAEK,MAAA;AACL,QAAA;AAEEC,UAAAA;AACS,YAAA;AACG,YAAA;AACL,cAAA;AACG,cAAA;AACA,cAAA;AACR,YAAA;AACD,UAAA;AAEHA,QAAAA;AACS,UAAA;AACI,UAAA;AACN,YAAA;AACG,YAAA;AACA,YAAA;AACR,UAAA;AACD,QAAA;AACL,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCC,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACG,UAAA;AACA,UAAA;AACX,QAAA;AACD,MAAA;AAEc,MAAA;AACT,QAAA;AAEED,UAAAA;AACY,YAAA;AACL,cAAA;AACG,cAAA;AACR,YAAA;AACD,UAAA;AAEHA,QAAAA;AACa,UAAA;AACN,YAAA;AACG,YAAA;AACR,UAAA;AACD,QAAA;AACL,QAAA;AACQ,UAAA;AACG,UAAA;AACCC,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACD,MAAA;AAEc,MAAA;AAGC,QAAA;AAEJ,MAAA;AAEC,MAAA;AACE,QAAA;AACH,QAAA;AACZ,MAAA;AAEO,MAAA;AACT,IAAA;AACF,EAAA;AACF;AAgB6B;AACrB,EAAA;AACJ,IAAA;AACQ,IAAA;AACD,MAAA;AACM,MAAA;AACb,IAAA;AAC2B,EAAA;AAEV,EAAA;AACDR,EAAAA;AAEE,EAAA;AACJ,EAAA;AACG,EAAA;AAEF,EAAA;AACA,IAAA;AACf,IAAA;AACD,EAAA;AACK,EAAA;AACW,IAAA;AACf,IAAA;AACD,EAAA;AAEgB,EAAA;AACEU,EAAAA;AACb,EAAA;AAEA,EAAA;AAEA,EAAA;AAIS,EAAA;AACK,IAAA;AACN,IAAA;AACM,IAAA;AACH,IAAA;AACG,IAAA;AACRD,IAAAA;AACA,IAAA;AACV,IAAA;AACF,EAAA;AAEa,EAAA;AACM,IAAA;AACN,IAAA;AACZ,EAAA;AAEU,EAAA;AACL,IAAA;AACJ,IAAA;AACQ,MAAA;AACG,MAAA;AACO,MAAA;AACND,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACO,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACO,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACA,MAAA;AACX,IAAA;AACD,EAAA;AAEkB,EAAA;AACb,IAAA;AACJ,IAAA;AACQ,MAAA;AACU,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACU,MAAA;AACNA,MAAAA;AACZ,IAAA;AACD,EAAA;AAEY,EAAA;AACE,IAAA;AACf,EAAA;AAEmB,EAAA;AACV,IAAA;AACT,EAAA;AAGE,EAAA;AAACN,IAAAA;AAAA,IAAA;AACO,MAAA;AACS,MAAA;AACL,MAAA;AACE,MAAA;AACZ,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACQ,MAAA;AACC,MAAA;AACP,QAAA;AACA,QAAA;AACF,MAAA;AAAA,IAAA;AACF,EAAA;AAEJ;AAEa;AP8eS;AACA;AG98Bb;AA4bLH;AAvZgB;AACDa,EAAAA;AACX,EAAA;AAEI,EAAA;AAEN,IAAA;AAEK;AAAA,oDAAA;AAEwD;AAAA,uBAAA;AAG/C,aAAA;AAAgG;AAAA,wCAAA;AAGpG,cAAA;AAAkB;AAAA;AAAA;AAAA;AAAA;AAQ5B,SAAA;AAEJ,EAAA;AAGE,EAAA;AAEK;AAAA,kDAAA;AAEwD;AAAA,qBAAA;AAG/C,WAAA;AAAY;AAAA;AAGhB,YAAA;AAAkB;AAAA;AAAA;AAAA;AAAA;AAQ5B,OAAA;AAEJ;AAWMN;AACQ,EAAA;AACO,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACY,EAAA;AACO,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACa,EAAA;AACM,IAAA;AACR,MAAA;AACT,IAAA;AACF,EAAA;AACU,EAAA;AACW,IAAA;AACT,MAAA;AAEF,MAAA;AACJ,QAAA;AACQ,QAAA;AACD,UAAA;AACM,UAAA;AACb,QAAA;AAC2B,MAAA;AACvB,MAAA;AACE,MAAA;AAEF,MAAA;AAEA,MAAA;AACK,QAAA;AACT,QAAA;AACD,MAAA;AAEK,MAAA;AACA,MAAA;AACA,MAAA;AAEU,MAAA;AACH,MAAA;AACE,MAAA;AACT,MAAA;AACA,MAAA;AACS,MAAA;AACb,QAAA;AACY,QAAA;AACZ,QAAA;AACc,QAAA;AAChB,MAAA;AAEM,MAAA;AAGA,MAAA;AACA,MAAA;AAEK,MAAA;AACL,QAAA;AAEEC,UAAAA;AACS,YAAA;AACG,YAAA;AACL,cAAA;AACG,cAAA;AACR,YAAA;AACD,UAAA;AAEHA,QAAAA;AACS,UAAA;AACI,UAAA;AACN,YAAA;AACG,YAAA;AACR,UAAA;AACD,QAAA;AACL,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCC,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACA,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACA,UAAA;AAAA,8BAAA;AACsE,uBAAA;AACjD,WAAA;AAElB,UAAA;AACX,QAAA;AACD,MAAA;AAEe,MAAA;AACXD,QAAAA;AACM,UAAA;AACI,UAAA;AACN,YAAA;AACG,YAAA;AACR,UAAA;AACD,QAAA;AACD,QAAA;AACQ,UAAA;AACG,UAAA;AACCC,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACI,UAAA;AACZ,QAAA;AACD,MAAA;AAEc,MAAA;AACT,QAAA;AAEED,UAAAA;AACY,YAAA;AACL,cAAA;AACG,cAAA;AACR,YAAA;AACD,UAAA;AAEHA,QAAAA;AACa,UAAA;AACN,YAAA;AACG,YAAA;AACR,UAAA;AACD,QAAA;AACL,QAAA;AACQ,UAAA;AACG,UAAA;AACCC,UAAAA;AACZ,QAAA;AACA,QAAA;AACQ,UAAA;AACG,UAAA;AACCA,UAAAA;AACZ,QAAA;AACD,MAAA;AAGC,MAAA;AAACN,QAAAA;AAAA,QAAA;AACK,UAAA;AACI,UAAA;AACI,UAAA;AACN,UAAA;AACD,YAAA;AACG,YAAA;AACN,YAAA;AAGU,YAAA;AACZ,UAAA;AAAA,QAAA;AACF,MAAA;AAEJ,IAAA;AACF,EAAA;AACF;AA2BsB;AACpB,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACAA,EAAAA;AACmB,EAAA;AACnB,EAAA;AACG,EAAA;AACgB;AACb,EAAA;AACJ,IAAA;AACQ,IAAA;AACD,MAAA;AACM,MAAA;AACb,IAAA;AAC2B,EAAA;AAEXF,EAAAA;AACE,EAAA;AAEJ,EAAA;AACH,EAAA;AACIY,EAAAA;AAEA,EAAA;AACA,IAAA;AACf,IAAA;AACD,EAAA;AACK,EAAA;AACW,IAAA;AACT,IAAA;AACN,IAAA;AACD,EAAA;AACK,EAAA;AACW,IAAA;AACf,IAAA;AACD,EAAA;AAEgB,EAAA;AACEF,EAAAA;AACC,EAAA;AACd,EAAA;AAES,EAAA;AACK,IAAA;AACRD,IAAAA;AACQ,IAAA;AACN,IAAA;AACM,IAAA;AACH,IAAA;AACjB,EAAA;AAEa,EAAA;AACX,IAAA;AACQ,MAAA;AACS,MAAA;AACjB,IAAA;AACiB,IAAA;AACT,IAAA;AACT,EAAA;AAEK,EAAA;AAGA,EAAA;AAIA,EAAA;AAEK,EAAA;AACL,IAAA;AACJ,IAAA;AACQ,MAAA;AACG,MAAA;AACO,MAAA;AACND,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACO,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACG,MAAA;AACO,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACA,MAAA;AACU,oBAAA;AACP,aAAA;AAAY,CAAA;AAEZ,MAAA;AACX,IAAA;AACD,EAAA;AAEe,EAAA;AACV,IAAA;AACJ,IAAA;AACQ,MAAA;AACU,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACU,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACU,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACI,MAAA;AACZ,IAAA;AACD,EAAA;AAEkB,EAAA;AACb,IAAA;AACJ,IAAA;AACQ,MAAA;AACU,MAAA;AACNA,MAAAA;AACZ,IAAA;AACA,IAAA;AACQ,MAAA;AACU,MAAA;AACNA,MAAAA;AACZ,IAAA;AACD,EAAA;AAEY,EAAA;AACL,IAAA;AACY,IAAA;AACJ,IAAA;AACD,IAAA;AACf,EAAA;AAGE,EAAA;AACEP,oBAAAA;AAAC,MAAA;AAAA,MAAA;AACe,QAAA;AACJ,QAAA;AACV,QAAA;AACM,QAAA;AACI,QAAA;AAAA,MAAA;AACZ,IAAA;AAEO,IAAA;AACJ,MAAA;AAAA,MAAA;AACW,QAAA;AACV,QAAA;AACY,QAAA;AACZ,QAAA;AACU,QAAA;AACA,QAAA;AAAM,MAAA;AAClB,IAAA;AAIA,IAAA;AAACC,MAAAA;AAAA,MAAA;AACc,QAAA;AACH,QAAA;AACD,QAAA;AACD,QAAA;AACI,QAAA;AACZ,QAAA;AACU,QAAA;AACD,QAAA;AACP,UAAA;AACA,UAAA;AACF,QAAA;AAAA,MAAA;AACF,IAAA;AAEJ,EAAA;AAEJ;AAcuB;AACf,EAAA;AACI,IAAA;AACG,MAAA;AACG,QAAA;AACV,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACF,MAAA;AACF,IAAA;AAC2B,EAAA;AAET,EAAA;AACFF,EAAAA;AAEF,EAAA;AACG,EAAA;AACN,EAAA;AACI,EAAA;AACX,EAAA;AACQa,IAAAA;AACb,EAAA;AAEmB,EAAA;AAEA,EAAA;AACHD,EAAAA;AACA,EAAA;AACX,EAAA;AACA,EAAA;AACS,EAAA;AAEC,EAAA;AACR,IAAA;AACR,EAAA;AAGE,EAAA;AACc,IAAA;AACZX,oBAAAA;AACAA,oBAAAA;AACAA,oBAAAA;AAAM,MAAA;AAAL,MAAA;AACO,QAAA;AACI,0BAAA;AACA,UAAA;AACA,0BAAA;AACA,0BAAA;AACA,0BAAA;AACI,UAAA;AACL,QAAA;AACE,QAAA;AACL,QAAA;AACI,QAAA;AAAA,MAAA;AACZ,IAAA;AAEAA,oBAAAA;AAEE,IAAA;AAEa,IAAA;AAGfA,oBAAAA;AACAA,oBAAAA;AAAC,MAAA;AAAA,MAAA;AACC,QAAA;AACUC,QAAAA;AACV,QAAA;AACA,QAAA;AACU,QAAA;AACA,QAAA;AACV,QAAA;AACA,QAAA;AACU,QAAA;AACE,QAAA;AACC,QAAA;AAA2B,MAAA;AAC1C,IAAA;AAEE,IAAA;AAAC,MAAA;AAAA,MAAA;AACC,QAAA;AACUA,QAAAA;AACV,QAAA;AACA,QAAA;AACA,QAAA;AACU,QAAA;AACV,QAAA;AACA,QAAA;AACU,QAAA;AACE,QAAA;AACC,QAAA;AAAmC,MAAA;AAClD,IAAA;AAEa,IAAA;AACZ,MAAA;AAAA,MAAA;AACC,QAAA;AACUA,QAAAA;AACV,QAAA;AACA,QAAA;AACU,QAAA;AACV,QAAA;AACA,QAAA;AACA,QAAA;AACU,QAAA;AACE,QAAA;AACC,QAAA;AAAmC,MAAA;AAClD,IAAA;AAEJ,EAAA;AAEJ;AAEkBI;AHu0BI;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"/home/runner/work/kubb/kubb/packages/plugin-react-query/dist/chunk-7ZODZVKP.cjs","sourcesContent":[null,"import transformers from '@kubb/core/transformers'\nimport { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\nimport { File, Function, useApp } from '@kubb/react'\nimport { pluginTsName } from '@kubb/plugin-ts'\n\nimport { SchemaType } from './SchemaType.tsx'\n\nimport { isRequired } from '@kubb/oas'\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ComponentProps, ComponentType, ReactNode } from 'react'\nimport type { FileMeta, PluginReactQuery } 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: string\n mutateParams: string\n /**\n * Options for JSdocs\n */\n JSDoc?: {\n comments: string[]\n }\n hook: {\n name: string\n generics?: string\n children?: string\n }\n client: {\n generics: string\n method: HttpMethod\n path: URLPath\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n contentType: string\n }\n dataReturnType: NonNullable<PluginReactQuery['options']['dataReturnType']>\n}\n\nfunction Template({ name, params, mutateParams, JSDoc, client, hook, dataReturnType }: TemplateProps): ReactNode {\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\n const clientOptions = [\n `method: \"${client.method}\"`,\n `url: ${client.path.template}`,\n client.withQueryParams ? 'params' : undefined,\n client.withData && !isFormData ? 'data' : undefined,\n client.withData && isFormData ? 'data: formData' : undefined,\n headers.length ? `headers: { ${headers}, ...clientOptions.headers }` : undefined,\n '...clientOptions',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\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 <File.Source name={name} isExportable isIndexable>\n <Function export name={name} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {} } = options ?? {}\n\n return ${hook.name}({\n mutationFn: async(${mutateParams}) => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n ...mutationOptions\n })`}\n </Function>\n </File.Source>\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 mutate,\n },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas, getFile } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const file = getFile(operation)\n const fileType = getFile(operation, { pluginKey: [pluginTsName] })\n\n return (\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 name={[\n schemas.request?.name,\n schemas.response.name,\n schemas.pathParams?.name,\n schemas.queryParams?.name,\n schemas.headerParams?.name,\n ...(schemas.errors?.map((error) => error.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n <File.Import\n name={['UseMutationOptions', 'UseMutationResult']}\n path={typeof mutate !== 'boolean' && mutate.importPath ? mutate.importPath : '@tanstack/react-query'}\n isTypeOnly\n />\n <File.Import name={['useMutation']} path={typeof mutate !== 'boolean' && mutate.importPath ? mutate.importPath : '@tanstack/react-query'} />\n {children}\n </File>\n )\n}\n\nconst defaultTemplates = { default: Template, root: RootTemplate } as const\n\ntype Templates = Partial<typeof defaultTemplates>\n\ntype MutationProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: ComponentType<ComponentProps<typeof Template>>\n}\n\nexport function Mutation({ Template = defaultTemplates.default }: MutationProps): ReactNode {\n // TODO do checks on pathParamsType\n\n const {\n plugin: {\n options: { dataReturnType, mutate },\n },\n } = useApp<PluginReactQuery>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const name = getName(operation, { type: 'function' })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const contentType = operation.getContentType()\n\n const params = new FunctionParams()\n const mutateParams = new FunctionParams()\n const factoryName = getName(operation, { type: 'type' })\n\n const requestType =\n mutate && mutate.variablesType === 'mutate'\n ? FunctionParams.toObject([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factoryName}['queryParams']`,\n enabled: !!schemas.queryParams?.name,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factoryName}['headerParams']`,\n enabled: !!schemas.headerParams?.name,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n type: `${factoryName}['request']`,\n enabled: !!schemas.request?.name,\n required: isRequired(schemas.request?.schema),\n },\n ])?.type\n : schemas.request?.name\n ? `${factoryName}['request']`\n : 'never'\n\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n generics: [`${factoryName}[\"data\"]`, `${factoryName}[\"error\"]`, requestType ? `${factoryName}[\"request\"]` : 'void'].join(', '),\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n contentType,\n }\n const hook = {\n name: 'useMutation',\n generics: [`${factoryName}['response']`, `${factoryName}[\"error\"]`, requestType ? `${requestType}` : 'void'].join(', '),\n }\n\n const resultGenerics = [\n `${factoryName}[\"response\"]`,\n `${factoryName}[\"error\"]`,\n mutate && mutate?.variablesType === 'mutate' ? requestType : `${factoryName}[\"request\"]`,\n ]\n\n if (mutate && mutate?.variablesType === 'mutate') {\n params.add([\n {\n name: 'options',\n type: `{\n mutation?: UseMutationOptions<${resultGenerics.join(', ')}>,\n client?: ${factoryName}['client']['parameters']\n }`,\n default: '{}',\n },\n ])\n\n mutateParams.add([\n [\n ...getASTParams(schemas.pathParams, { typed: false }),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n enabled: !!schemas.request?.name,\n required: isRequired(schemas.request?.schema),\n },\n ],\n ])\n } else {\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factoryName}['queryParams']`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factoryName}['headerParams']`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'options',\n type: `{\n mutation?: UseMutationOptions<${resultGenerics.join(', ')}>,\n client?: ${factoryName}['client']['parameters']\n }`,\n default: '{}',\n },\n ])\n\n mutateParams.add([\n {\n name: 'data',\n enabled: !!schemas.request?.name,\n required: isRequired(schemas.request?.schema),\n },\n ])\n }\n\n if (!mutate) {\n return null\n }\n\n return (\n <>\n <Template\n name={name}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n mutateParams={mutateParams.toString()}\n dataReturnType={dataReturnType}\n />\n </>\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: Templates\n}\n\nMutation.File = function ({ ...props }: FileProps): ReactNode {\n const templates = { ...defaultTemplates, ...props.templates }\n\n const Template = templates.default\n const RootTemplate = templates.root\n\n return (\n <RootTemplate>\n <SchemaType />\n <Mutation Template={Template} />\n </RootTemplate>\n )\n}\n\nMutation.templates = defaultTemplates\n","import { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { File, Type, useApp } from '@kubb/react'\n\nimport type { ReactNode } from 'react'\nimport type { PluginReactQuery } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-ts'\n\nexport function SchemaType(): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginReactQuery>()\n const { getSchemas, getName } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n const [TData, TError, TRequest, TPathParams, TQueryParams, THeaderParams, TResponse] = [\n schemas.response.name,\n schemas.errors?.map((item) => item.name).join(' | ') || 'never',\n schemas.request?.name || 'never',\n schemas.pathParams?.name || 'never',\n schemas.queryParams?.name || 'never',\n schemas.headerParams?.name || 'never',\n schemas.response.name,\n ]\n const factoryName = getName(operation, { type: 'type' })\n\n const clientType = `${factoryName}Client`\n const isFormData = operation.getContentType() === 'multipart/form-data'\n\n return (\n <>\n <File.Source name={clientType} isTypeOnly>\n <Type name={clientType}>{`typeof client<${TResponse}, ${TError}, ${isFormData ? 'FormData' : TRequest}>`}</Type>\n </File.Source>\n <File.Source name={factoryName} isTypeOnly>\n <Type name={factoryName}>\n {`\n {\n data: ${TData}\n error: ${TError}\n request: ${isFormData ? 'FormData' : TRequest}\n pathParams: ${TPathParams}\n queryParams: ${TQueryParams}\n headerParams: ${THeaderParams}\n response: ${dataReturnType === 'data' ? TData : `Awaited<ReturnType<${clientType}>>`}\n client: {\n parameters: Partial<Parameters<${clientType}>[0]>\n return: Awaited<ReturnType<${clientType}>>\n }\n }\n `}\n </Type>\n </File.Source>\n </>\n )\n}\n","import { PackageManager } from '@kubb/core'\nimport transformers from '@kubb/core/transformers'\nimport { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { File, Function, useApp } from '@kubb/react'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\n\nimport { getImportNames, reactQueryDepRegex } from '../utils.ts'\nimport { QueryImports } from './QueryImports.tsx'\nimport { QueryKey } from './QueryKey.tsx'\nimport { QueryOptions } from './QueryOptions.tsx'\nimport { SchemaType } from './SchemaType.tsx'\n\nimport { isRequired } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { QueryOptions as QueryOptionsPluginOptions, Query as QueryPluginOptions } from '../types.ts'\nimport type { FileMeta, Infinite, PluginReactQuery, Suspense } 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: string\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 hook: {\n name: string\n generics?: string\n queryKey: string\n queryOptions: string\n }\n infinite: Infinite | false\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, hook, infinite }: TemplateProps): ReactNode {\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const resolvedReturnType = `${returnType} & { queryKey: TQueryKey }`\n\n if (isV5) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={resolvedReturnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {} } = options ?? {}\n const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}\n\n const query = ${hook.name}({\n ...${hook.queryOptions} as unknown as ${infinite ? 'InfiniteQueryObserverOptions' : 'QueryObserverOptions'},\n queryKey,\n ...queryOptions as unknown as ${infinite ? 'Omit<InfiniteQueryObserverOptions, \"queryKey\">' : 'Omit<QueryObserverOptions, \"queryKey\">'}\n }) as ${resolvedReturnType}\n\n query.queryKey = queryKey as TQueryKey\n\n return query\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={resolvedReturnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {} } = options ?? {}\n const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}\n\n const query = ${hook.name}<${hook.generics}>({\n ...${hook.queryOptions},\n queryKey,\n ...queryOptions\n }) as ${resolvedReturnType}\n\n query.queryKey = queryKey as TQueryKey\n\n return query\n\n `}\n </Function>\n </File.Source>\n )\n}\n\ntype FrameworkProps = TemplateProps & {\n context: {\n factory: {\n name: string\n }\n queryKey: string\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get solid() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get svelte() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get vue() {\n return function ({ context, hook, ...rest }: FrameworkProps): ReactNode {\n const { factory, queryKey } = context\n\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n const operation = useOperation()\n const { getSchemas } = useOperationManager()\n\n const importNames = getImportNames()\n\n const queryOptions = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n\n const hookName = rest.infinite ? importNames.queryInfinite.vue.hookName : importNames.query.vue.hookName\n const resultType = rest.infinite ? importNames.queryInfinite.vue.resultType : importNames.query.vue.resultType\n const optionsType = rest.infinite ? importNames.queryInfinite.vue.optionsType : importNames.query.vue.optionsType\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n const client = {\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n }\n\n const resultGenerics = ['TData', `${factory.name}['error']`]\n\n // only needed for the options to override the useQuery options/params\n const queryOptionsOverrideGenerics = [`${factory.name}['response']`, `${factory.name}['error']`, 'TData', 'TQueryKey']\n const queryOptionsGenerics = ['TData', 'TQueryData']\n\n params.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n })),\n {\n name: 'refParams',\n type: `MaybeRef<${schemas.queryParams?.name}>`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refHeaders',\n type: `MaybeRef<${schemas.headerParams?.name}>`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'refData',\n type: `MaybeRef<${schemas.request?.name}>`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `{\n query?: Partial<${optionsType}<${queryOptionsOverrideGenerics.join(', ')}>>,\n client?: ${factory.name}['client']['parameters']\n }`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...getASTParams(schemas.pathParams, {\n typed: false,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n {\n name: 'refParams',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refHeaders',\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n })),\n {\n name: 'refParams',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refData',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n return (\n <Template\n {...rest}\n params={params.toString()}\n returnType={`${resultType}<${resultGenerics.join(', ')}>`}\n hook={{\n ...hook,\n name: hookName,\n queryOptions: isV5\n ? `${queryOptions}(${queryParams.toString()})`\n : `${queryOptions}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n }}\n />\n )\n }\n },\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n resultType: string\n hookName: string\n optionsType: string\n infinite: Infinite | false\n query: QueryPluginOptions | false\n queryOptions: QueryOptionsPluginOptions | false\n suspense: Suspense | false\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryKeyTemplate?: React.ComponentType<React.ComponentProps<typeof QueryKey.templates.react>>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryOptionsTemplate?: React.ComponentType<React.ComponentProps<typeof QueryOptions.templates.react>>\n}\n\nexport function Query({\n factory,\n optionsType,\n hookName,\n resultType,\n Template = defaultTemplates.react,\n QueryKeyTemplate = QueryKey.templates.react,\n QueryOptionsTemplate = QueryOptions.templates.react,\n ...props\n}: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { dataReturnType, pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const name = getName(operation, { type: 'function' })\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n\n const queryKey = pluginManager.resolveName({\n name: [factory.name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined, 'QueryKey'].filter(Boolean).join(''),\n pluginKey,\n })\n const queryKeyType = pluginManager.resolveName({\n name: [factory.name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined, 'QueryKey'].filter(Boolean).join(''),\n type: 'type',\n pluginKey,\n })\n const queryOptions = pluginManager.resolveName({\n name: [factory.name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined, 'QueryOptions'].filter(Boolean).join(''),\n pluginKey,\n })\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n //TODO operationManager.getCleitn\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n }\n\n generics.add([\n {\n type: 'TData',\n default: props.infinite ? `InfiniteData<${factory.name}[\"response\"]>` : `${factory.name}[\"response\"]`,\n },\n props.suspense ? undefined : { type: 'TQueryData', default: `${factory.name}[\"response\"]` },\n { type: 'TQueryKey extends QueryKey', default: queryKeyType },\n ])\n\n const resultGenerics = ['TData', `${factory.name}['error']`]\n // only needed for the options to override the useQuery options/params\n // suspense is having 4 generics instead of 5, TQueryData is not needed because data will always be defined\n const queryOptionsOverrideGenerics = props.suspense\n ? [`${factory.name}['response']`, `${factory.name}['error']`, 'TData', 'TQueryKey']\n : [`${factory.name}['response']`, `${factory.name}['error']`, 'TData', 'TQueryData', 'TQueryKey']\n\n const queryOptionsGenerics = props.suspense ? ['TData'] : ['TData', 'TQueryData']\n\n params.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams, { typed: true })] : getASTParams(schemas.pathParams, { typed: true })),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n type: `${factory.name}['request']`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `{\n query?: Partial<${optionsType}<${queryOptionsOverrideGenerics.join(', ')}>>,\n client?: ${factory.name}['client']['parameters']\n}`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams)] : getASTParams(schemas.pathParams)),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams)] : getASTParams(schemas.pathParams)),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'data',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const hook = {\n name: hookName,\n generics: [isV5 ? 'any' : `${factory.name}['data']`, `${factory.name}['error']`, 'TData', 'any'].join(', '),\n queryOptions: isV5 ? `${queryOptions}(${queryParams.toString()})` : `${queryOptions}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n }\n\n return (\n <>\n <QueryKey\n keysFn={props.query ? props.query.queryKey : (keys: unknown[]) => keys}\n Template={QueryKeyTemplate}\n factory={factory}\n name={queryKey}\n typeName={queryKeyType}\n />\n\n {props.queryOptions && (\n <QueryOptions\n Template={QueryOptionsTemplate}\n factory={factory}\n resultType={optionsType}\n dataReturnType={dataReturnType}\n infinite={props.infinite}\n suspense={props.suspense}\n />\n )}\n\n {props.query && (\n <Template\n name={[name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined].filter(Boolean).join('')}\n generics={generics.toString()}\n JSDoc={{ comments: getComments(operation) }}\n params={params.toString()}\n returnType={`${resultType}<${resultGenerics.join(', ')}>`}\n hook={hook}\n infinite={props.infinite}\n context={{\n factory,\n queryKey,\n }}\n />\n )}\n </>\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: {\n query: typeof defaultTemplates\n queryKey: typeof QueryKey.templates\n queryOptions: typeof QueryOptions.templates\n queryImports: typeof QueryImports.templates\n }\n}\n\nQuery.File = function ({ templates }: FileProps): ReactNode {\n const {\n plugin: {\n options: {\n client: { importPath },\n infinite,\n suspense,\n query,\n queryOptions,\n parser,\n },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas, getFile, getName } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n const file = getFile(operation)\n const fileType = getFile(operation, { pluginKey: [pluginTsName] })\n const fileZodSchemas = getFile(operation, {\n pluginKey: [pluginZodName],\n })\n\n const factoryName = getName(operation, { type: 'type' })\n\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const Template = templates?.query['react'] || defaultTemplates['react']\n const QueryOptionsTemplate = templates?.queryOptions['react'] || QueryOptions.templates['react']\n const QueryKeyTemplate = templates?.queryKey['react'] || QueryKey.templates['react']\n const Import = templates?.queryImports['react'] || QueryImports.templates['react']\n\n const factory = {\n name: factoryName,\n }\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n {parser === 'zod' && <File.Import name={[zodSchemas.response?.name]} root={file.path} path={fileZodSchemas.path} />}\n <File.Import name={'client'} path={importPath} />\n <File.Import name={['ResponseConfig']} path={importPath} isTypeOnly />\n <File.Import\n name={[\n schemas.request?.name,\n schemas.response.name,\n schemas.pathParams?.name,\n schemas.queryParams?.name,\n schemas.headerParams?.name,\n ...(schemas.errors?.map((error) => error.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n\n <QueryImports hookPath={typeof query !== 'boolean' ? query.importPath : undefined} Template={Import} isInfinite={false} isSuspense={false} />\n {!!infinite && (\n <QueryImports hookPath={typeof query !== 'boolean' ? query.importPath : undefined} Template={Import} isInfinite={true} isSuspense={false} />\n )}\n {!!suspense && isV5 && (\n <QueryImports hookPath={typeof query !== 'boolean' ? query.importPath : undefined} Template={Import} isInfinite={false} isSuspense={true} />\n )}\n <SchemaType />\n <Query\n factory={factory}\n Template={Template}\n QueryKeyTemplate={QueryKeyTemplate}\n QueryOptionsTemplate={QueryOptionsTemplate}\n infinite={false}\n suspense={false}\n query={query}\n queryOptions={queryOptions}\n hookName={importNames.query['react'].hookName}\n resultType={importNames.query['react'].resultType}\n optionsType={importNames.query['react'].optionsType}\n />\n {!!infinite && (\n <Query\n factory={factory}\n Template={Template}\n QueryKeyTemplate={QueryKeyTemplate}\n QueryOptionsTemplate={QueryOptionsTemplate}\n infinite={infinite}\n suspense={false}\n query={query}\n queryOptions={queryOptions}\n hookName={importNames.queryInfinite['react'].hookName}\n resultType={importNames.queryInfinite['react'].resultType}\n optionsType={importNames.queryInfinite['react'].optionsType}\n />\n )}\n {!!suspense && isV5 && (\n <Query\n factory={factory}\n Template={Template}\n QueryKeyTemplate={QueryKeyTemplate}\n QueryOptionsTemplate={QueryOptionsTemplate}\n infinite={false}\n suspense={suspense}\n query={query}\n queryOptions={queryOptions}\n hookName={importNames.querySuspense['react'].hookName}\n resultType={importNames.querySuspense['react'].resultType}\n optionsType={importNames.querySuspense['react'].optionsType}\n />\n )}\n </File>\n )\n}\n\nQuery.templates = defaultTemplates\n","import { PackageManager } from '@kubb/core'\n\nexport const reactQueryDepRegex = /@tanstack\\/(react|solid|vue|svelte)-query/\n\nexport function getImportNames() {\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n\n return {\n mutation: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useMutation',\n optionsType: 'UseMutationOptions',\n resultType: 'UseMutationResult',\n },\n solid: {\n path: '@tanstack/solid-query',\n hookName: 'createMutation',\n optionsType: 'CreateMutationOptions',\n resultType: 'CreateMutationResult',\n },\n svelte: {\n path: '@tanstack/svelte-query',\n hookName: 'createMutation',\n optionsType: 'CreateMutationOptions',\n resultType: 'CreateMutationResult',\n },\n vue: {\n path: '@tanstack/vue-query',\n hookName: 'useMutation',\n optionsType: isV5 ? 'UseMutationOptions' : 'VueMutationObserverOptions',\n resultType: 'UseMutationReturnType',\n },\n },\n query: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useQuery',\n optionsType: isV5 ? 'QueryObserverOptions' : 'UseBaseQueryOptions',\n resultType: 'UseQueryResult',\n },\n solid: {\n path: '@tanstack/solid-query',\n hookName: 'createQuery',\n optionsType: 'CreateBaseQueryOptions',\n resultType: 'CreateQueryResult',\n },\n svelte: {\n path: '@tanstack/svelte-query',\n hookName: 'createQuery',\n optionsType: 'CreateBaseQueryOptions',\n resultType: 'CreateQueryResult',\n },\n vue: {\n path: '@tanstack/vue-query',\n hookName: 'useQuery',\n optionsType: isV5 ? 'QueryObserverOptions' : 'VueQueryObserverOptions',\n resultType: isV5 ? 'UseQueryReturnType' : 'UseQueryReturnType',\n },\n },\n queryInfinite: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useInfiniteQuery',\n optionsType: isV5 ? 'InfiniteQueryObserverOptions' : 'UseInfiniteQueryOptions',\n resultType: 'UseInfiniteQueryResult',\n },\n solid: {\n path: '@tanstack/solid-query',\n hookName: 'createInfiniteQuery',\n optionsType: 'CreateInfiniteQueryOptions',\n resultType: 'CreateInfiniteQueryResult',\n },\n svelte: {\n path: '@tanstack/svelte-query',\n hookName: 'createInfiniteQuery',\n optionsType: 'CreateInfiniteQueryOptions',\n resultType: 'CreateInfiniteQueryResult',\n },\n vue: {\n path: '@tanstack/vue-query',\n hookName: 'useInfiniteQuery',\n optionsType: isV5 ? 'UseInfiniteQueryOptions' : 'VueInfiniteQueryObserverOptions',\n resultType: isV5 ? 'UseInfiniteQueryReturnType' : 'VueInfiniteQueryObserverOptions',\n },\n },\n querySuspense: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useSuspenseQuery',\n optionsType: 'UseSuspenseQueryOptions',\n resultType: 'UseSuspenseQueryResult',\n },\n },\n } as const\n}\n","import { PackageManager } from '@kubb/core'\nimport { File } from '@kubb/react'\n\nimport { getImportNames, reactQueryDepRegex } from '../utils.ts'\n\nimport type { ReactNode } from 'react'\n\ntype TemplateProps = {\n /**\n * Path to @tanstack-query\n */\n path: string\n /**\n * Override the path of 'useQuery'\n * @default 'path'\n */\n hookPath: string | undefined\n optionsType: string\n queryOptions: string | undefined\n resultType: string\n hookName: string\n isInfinite: boolean\n}\n\nfunction Template({ path, hookPath = path, isInfinite, hookName, queryOptions, optionsType, resultType }: TemplateProps): ReactNode {\n return (\n <>\n <File.Import name={[optionsType, resultType]} path={path} isTypeOnly />\n <File.Import name={[hookName]} path={hookPath} />\n\n {queryOptions && <File.Import name={[queryOptions].filter(Boolean)} path={path} />}\n <File.Import name={['QueryKey', 'WithRequired', isInfinite ? 'InfiniteData' : undefined].filter(Boolean)} path={path} isTypeOnly />\n </>\n )\n}\n\ntype FrameworkProps = Partial<TemplateProps> & {\n context: {\n isInfinite: boolean\n isSuspense: boolean\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite, isSuspense } = context\n\n return (\n <Template\n isInfinite={isInfinite}\n {...(isSuspense ? importNames.querySuspense.react : isInfinite ? importNames.queryInfinite.react : importNames.query.react)}\n queryOptions={isV5 ? (isInfinite ? 'infiniteQueryOptions' : 'queryOptions') : undefined}\n hookPath={hookPath}\n {...rest}\n />\n )\n }\n },\n get solid() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite } = context\n\n return (\n <Template\n isInfinite={isInfinite}\n {...(isInfinite ? importNames.queryInfinite.solid : importNames.query.solid)}\n queryOptions={isV5 ? (isInfinite ? 'infiniteQueryOptions' : 'queryOptions') : undefined}\n hookPath={hookPath}\n {...rest}\n />\n )\n }\n },\n get svelte() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite } = context\n\n return (\n <Template\n isInfinite={isInfinite}\n {...(isInfinite ? importNames.queryInfinite.svelte : importNames.query.svelte)}\n queryOptions={isV5 ? (isInfinite ? 'infiniteQueryOptions' : 'queryOptions') : undefined}\n hookPath={hookPath}\n {...rest}\n />\n )\n }\n },\n get vue() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite } = context\n const path = '@tanstack/vue-query'\n\n return (\n <>\n {isV5 && (\n <>\n <Template\n isInfinite={isInfinite}\n {...(isInfinite ? importNames.queryInfinite.vue : importNames.query.vue)}\n queryOptions={isInfinite ? 'infiniteQueryOptions' : 'queryOptions'}\n hookPath={hookPath}\n {...rest}\n />\n <File.Import name={['QueryObserverOptions']} path={path} isTypeOnly />\n </>\n )}\n\n {!isV5 && isInfinite && (\n <>\n <File.Import name={[importNames.queryInfinite.vue.resultType]} path={path} isTypeOnly />\n <File.Import name={[importNames.queryInfinite.vue.optionsType]} path={'@tanstack/vue-query/build/lib/types'} isTypeOnly />\n <File.Import name={[importNames.queryInfinite.vue.hookName]} path={path} />\n </>\n )}\n\n {!isV5 && !isInfinite && (\n <>\n <File.Import name={[importNames.query.vue.resultType]} path={path} isTypeOnly />\n <File.Import name={[importNames.query.vue.optionsType]} path={'@tanstack/vue-query/build/lib/types'} isTypeOnly />\n <File.Import name={[importNames.query.vue.hookName]} path={path} />\n </>\n )}\n <File.Import name={['unref']} path={'vue'} />\n <File.Import name={['MaybeRef']} path={'vue'} isTypeOnly />\n <File.Import name={['QueryKey', 'WithRequired']} path={path} isTypeOnly />\n </>\n )\n }\n },\n} as const\n\ntype Props = {\n hookPath: string | undefined\n isInfinite: boolean\n /**\n * Only for React and v5\n */\n isSuspense: boolean\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n}\n\nexport function QueryImports({ hookPath, isInfinite, isSuspense, Template = defaultTemplates.react }: Props): ReactNode {\n return (\n <Template\n hookPath={hookPath}\n context={{\n isInfinite,\n isSuspense,\n }}\n />\n )\n}\n\nQueryImports.templates = defaultTemplates\n","import { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams } from '@kubb/plugin-oas/utils'\nimport { File, Function, Type, useApp } from '@kubb/react'\n\nimport { isRequired } from '@kubb/oas'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport type { ReactNode } from 'react'\nimport type { PluginReactQuery } from '../types'\n\ntype TemplateProps = {\n /**\n * Name of the function\n */\n name: string\n /**\n * TypeName of the function in PascalCase\n */\n typeName: string\n /**\n * Parameters/options/props that need to be used\n */\n params: string\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 keys?: string\n}\n\nfunction Template({ name, typeName, params, generics, returnType, JSDoc, keys }: TemplateProps): ReactNode {\n return (\n <>\n <File.Source name={name} isExportable isIndexable>\n <Function.Arrow name={name} export generics={generics} params={params} returnType={returnType} singleLine JSDoc={JSDoc}>\n {`[${keys}] as const`}\n </Function.Arrow>\n </File.Source>\n\n <File.Source name={typeName} isExportable isIndexable isTypeOnly>\n <Type name={typeName} export>\n {`ReturnType<typeof ${name}>`}\n </Type>\n </File.Source>\n </>\n )\n}\n\ntype FrameworkProps = TemplateProps & {\n context: {\n factory: {\n name: string\n }\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get solid() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get svelte() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get vue() {\n return function ({ context, ...rest }: FrameworkProps): ReactNode {\n const { factory } = context\n\n const {\n plugin: {\n options: { pathParamsType, query },\n },\n } = useApp<PluginReactQuery>()\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const path = new URLPath(operation.path)\n const params = new FunctionParams()\n const withQueryParams = !!schemas.queryParams?.name\n const withRequest = !!schemas.request?.name\n\n params.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n type: `MaybeRef<${item.type}>`,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n type: `MaybeRef<${item.type}>`,\n }),\n })),\n {\n name: 'params',\n type: `MaybeRef<${`${factory.name}[\"queryParams\"]`}>`,\n enabled: withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'request',\n type: `MaybeRef<${`${factory.name}[\"request\"]`}>`,\n enabled: withRequest,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const keys = [\n path.toObject({\n type: 'path',\n stringify: true,\n replacer: (pathParam) => `unref(${pathParam})`,\n }),\n withQueryParams ? '...(params ? [params] : [])' : undefined,\n withRequest ? '...(request ? [request] : [])' : undefined,\n ].filter(Boolean)\n\n return <Template {...rest} params={params.toString()} keys={keys.join(', ')} />\n }\n },\n} as const\n\ntype Props = {\n name: string\n typeName: string\n keysFn: (keys: unknown[]) => unknown[]\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n}\n\nexport function QueryKey({ name, typeName, factory, keysFn, Template = defaultTemplates.react }: Props): ReactNode {\n const {\n plugin: {\n options: { pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const path = new URLPath(operation.path)\n const params = new FunctionParams()\n const withQueryParams = !!schemas.queryParams?.name\n const withRequest = !!schemas.request?.name\n\n params.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams, { typed: true })] : getASTParams(schemas.pathParams, { typed: true })),\n {\n name: 'params',\n type: `${factory.name}[\"queryParams\"]`,\n enabled: withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'data',\n type: `${factory.name}[\"request\"]`,\n enabled: withRequest,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const keys = [\n path.toObject({\n type: 'path',\n stringify: true,\n }),\n withQueryParams ? '...(params ? [params] : [])' : undefined,\n withRequest ? '...(data ? [data] : [])' : undefined,\n ].filter(Boolean)\n\n return <Template typeName={typeName} name={name} params={params.toString()} keys={keysFn(keys).join(', ')} context={{ factory }} />\n}\n\nQueryKey.templates = defaultTemplates\n","import { PackageManager } from '@kubb/core'\nimport transformers from '@kubb/core/transformers'\nimport { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams } from '@kubb/plugin-oas/utils'\nimport { Function, useApp, File } from '@kubb/react'\nimport { pluginZodName } from '@kubb/plugin-zod'\n\nimport { isRequired } from '@kubb/oas'\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { Infinite, PluginReactQuery, Suspense } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { reactQueryDepRegex } from '../utils.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: string\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 hook: {\n queryKey: string\n children?: string\n }\n client: {\n generics: string\n method: HttpMethod\n path: URLPath\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n contentType: string\n }\n infinite: Infinite | false\n dataReturnType: NonNullable<PluginReactQuery['options']['dataReturnType']>\n parser: string | undefined\n}\n\nfunction Template({ name, params, generics, returnType, JSDoc, hook, client, infinite, dataReturnType, parser }: TemplateProps): ReactNode {\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\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\n const clientOptions = [\n `method: \"${client.method}\"`,\n `url: ${client.path.template}`,\n client.withQueryParams && !infinite ? 'params' : undefined,\n client.withData && !isFormData ? 'data' : undefined,\n client.withData && isFormData ? 'data: formData' : undefined,\n headers.length ? `headers: { ${headers}, ...options.headers }` : undefined,\n '...options',\n client.withQueryParams && !!infinite\n ? `params: {\n ...params,\n ['${infinite.queryParam}']: pageParam,\n ...(options.params || {}),\n }`\n : undefined,\n ].filter(Boolean)\n\n const queryOptions = [\n isV5 && !!infinite ? `initialPageParam: ${infinite.initialPageParam}` : undefined,\n isV5 && !!infinite && !!infinite.cursorParam ? `getNextPageParam: (lastPage) => lastPage['${infinite.cursorParam}']` : undefined,\n isV5 && !!infinite && !!infinite.cursorParam ? `getPreviousPageParam: (firstPage) => firstPage['${infinite.cursorParam}']` : undefined,\n isV5 && !!infinite && !infinite.cursorParam && dataReturnType === 'full'\n ? 'getNextPageParam: (lastPage, _allPages, lastPageParam) => Array.isArray(lastPage.data) && lastPage.data.length === 0 ? undefined : lastPageParam + 1'\n : undefined,\n isV5 && !!infinite && !infinite.cursorParam && dataReturnType === 'data'\n ? 'getNextPageParam: (lastPage, _allPages, lastPageParam) => Array.isArray(lastPage) && lastPage.length === 0 ? undefined : lastPageParam + 1'\n : undefined,\n isV5 && !!infinite && !infinite.cursorParam\n ? 'getPreviousPageParam: (_firstPage, _allPages, firstPageParam) => firstPageParam <= 1 ? undefined : firstPageParam - 1'\n : undefined,\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n const resolvedQueryOptions = `${transformers.createIndent(4)}${queryOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n\n let returnRes = parser ? `return ${parser}(res.data)` : 'return res.data'\n\n if (dataReturnType === 'full') {\n returnRes = parser ? `return {...res, data: ${parser}(res.data)}` : 'return res'\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 if (infinite) {\n if (isV5) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return infiniteQueryOptions({\n queryKey,\n queryFn: async ({ pageParam }) => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n })\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return {\n queryKey,\n queryFn: async ({ pageParam }) => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n }\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n if (isV5) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return queryOptions({\n queryKey,\n queryFn: async () => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n })\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return {\n queryKey,\n queryFn: async () => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n }\n\n `}\n </Function>\n </File.Source>\n )\n}\n\ntype FrameworkProps = TemplateProps & {\n context: {\n factory: {\n name: string\n }\n queryKey: string\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get solid() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get svelte() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get vue() {\n return function ({ client, context, ...rest }: FrameworkProps): ReactNode {\n const { factory, queryKey } = context\n\n const {\n plugin: {\n options: { pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const params = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n\n params.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n type: `MaybeRef<${item.type}>`,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n type: `MaybeRef<${item.type}>`,\n }),\n })),\n {\n name: 'refParams',\n type: `MaybeRef<${schemas.queryParams?.name}>`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refHeaders',\n type: `MaybeRef<${schemas.headerParams?.name}>`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'refData',\n type: `MaybeRef<${schemas.request?.name}>`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n })),\n {\n name: 'refParams',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refData',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const unrefs = params.items\n .filter((item) => item.enabled)\n .map((item) => {\n return item.name ? `const ${transformers.camelCase(item.name.replace('ref', ''))} = unref(${item.name})` : undefined\n })\n .join('\\n')\n\n const hook = {\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n children: unrefs,\n }\n\n return <Template {...rest} params={params.toString()} hook={hook} client={client} />\n }\n },\n} as const\n\ntype Props = {\n infinite: Infinite | false\n suspense: Suspense | false\n factory: {\n name: string\n }\n resultType: string\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n dataReturnType: NonNullable<PluginReactQuery['options']['dataReturnType']>\n}\n\nexport function QueryOptions({ factory, infinite, suspense, resultType, dataReturnType, Template = defaultTemplates.react }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { parser, pathParamsType, queryOptions },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const contentType = operation.getContentType()\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n\n const queryKey = pluginManager.resolveName({\n name: [factory.name, infinite ? 'Infinite' : undefined, suspense ? 'Suspense' : undefined, 'QueryKey'].filter(Boolean).join(''),\n pluginKey,\n })\n const queryOptionsName = pluginManager.resolveName({\n name: [factory.name, infinite ? 'Infinite' : undefined, suspense ? 'Suspense' : undefined, 'QueryOptions'].filter(Boolean).join(''),\n pluginKey,\n })\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n\n const clientGenerics = [`${factory.name}['data']`, `${factory.name}['error']`]\n // suspense is having 4 generics instead of 5, TQueryData is not needed because data will always be defined\n const resultGenerics = suspense\n ? [`${factory.name}['response']`, `${factory.name}[\"error\"]`, 'TData']\n : [`${factory.name}['response']`, `${factory.name}[\"error\"]`, 'TData', 'TQueryData']\n\n const client = {\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n method: operation.method,\n path: new URLPath(operation.path),\n generics: clientGenerics.toString(),\n contentType,\n }\n\n generics.add([\n { type: 'TData', default: `${factory.name}[\"response\"]` },\n suspense ? undefined : { type: 'TQueryData', default: `${factory.name}[\"response\"]` },\n ])\n\n params.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams, { typed: true })] : getASTParams(schemas.pathParams, { typed: true })),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n type: `${factory.name}['request']`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams)] : getASTParams(schemas.pathParams)),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'data',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const hook = {\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n }\n\n if (!queryOptions) {\n return null\n }\n\n return (\n <Template\n name={queryOptionsName}\n params={params.toString()}\n generics={generics.toString()}\n returnType={`WithRequired<${resultType}<${resultGenerics.join(', ')}>, 'queryKey'>`}\n client={client}\n hook={hook}\n infinite={infinite}\n dataReturnType={dataReturnType}\n parser={parser === 'zod' ? `${zodSchemas.response.name}.parse` : undefined}\n context={{\n factory,\n queryKey,\n }}\n />\n )\n}\n\nQueryOptions.templates = defaultTemplates\n"]}
@@ -83,7 +83,7 @@ ${transformers.createIndent(4)}`)}`;
83
83
  })
84
84
  }
85
85
  ` : void 0;
86
- return /* @__PURE__ */ jsx2(File2.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx2(Function, { export: true, name, params, JSDoc, children: `
86
+ return /* @__PURE__ */ jsx2(File2.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx2(Function, { export: true, name, params, JSDoc, children: `
87
87
  const { mutation: mutationOptions, client: clientOptions = {} } = options ?? {}
88
88
 
89
89
  return ${hook.name}({
@@ -519,8 +519,8 @@ import { pluginTsName as pluginTsName3 } from "@kubb/plugin-ts";
519
519
  import { Fragment as Fragment4, jsx as jsx4, jsxs as jsxs4 } from "@kubb/react/jsx-runtime";
520
520
  function Template3({ name, typeName, params, generics, returnType, JSDoc, keys }) {
521
521
  return /* @__PURE__ */ jsxs4(Fragment4, { children: [
522
- /* @__PURE__ */ jsx4(File4.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx4(Function2.Arrow, { name, export: true, generics, params, returnType, singleLine: true, JSDoc, children: `[${keys}] as const` }) }),
523
- /* @__PURE__ */ jsx4(File4.Source, { name: typeName, isExportable: true, isTypeOnly: true, children: /* @__PURE__ */ jsx4(Type2, { name: typeName, export: true, children: `ReturnType<typeof ${name}>` }) })
522
+ /* @__PURE__ */ jsx4(File4.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx4(Function2.Arrow, { name, export: true, generics, params, returnType, singleLine: true, JSDoc, children: `[${keys}] as const` }) }),
523
+ /* @__PURE__ */ jsx4(File4.Source, { name: typeName, isExportable: true, isIndexable: true, isTypeOnly: true, children: /* @__PURE__ */ jsx4(Type2, { name: typeName, export: true, children: `ReturnType<typeof ${name}>` }) })
524
524
  ] });
525
525
  }
526
526
  var defaultTemplates3 = {
@@ -697,7 +697,7 @@ ${transformers2.createIndent(4)}`)}`;
697
697
  ` : void 0;
698
698
  if (infinite) {
699
699
  if (isV5) {
700
- return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, params, JSDoc, children: `
700
+ return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, params, JSDoc, children: `
701
701
  const queryKey = ${hook.queryKey}
702
702
 
703
703
  return infiniteQueryOptions({
@@ -716,7 +716,7 @@ ${transformers2.createIndent(4)}`)}`;
716
716
 
717
717
  ` }) });
718
718
  }
719
- return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
719
+ return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
720
720
  const queryKey = ${hook.queryKey}
721
721
 
722
722
  return {
@@ -736,7 +736,7 @@ ${transformers2.createIndent(4)}`)}`;
736
736
  ` }) });
737
737
  }
738
738
  if (isV5) {
739
- return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, params, JSDoc, children: `
739
+ return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, params, JSDoc, children: `
740
740
  const queryKey = ${hook.queryKey}
741
741
 
742
742
  return queryOptions({
@@ -755,7 +755,7 @@ ${transformers2.createIndent(4)}`)}`;
755
755
 
756
756
  ` }) });
757
757
  }
758
- return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
758
+ return /* @__PURE__ */ jsx5(File5.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx5(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
759
759
  const queryKey = ${hook.queryKey}
760
760
 
761
761
  return {
@@ -994,7 +994,7 @@ function Template5({ name, generics, returnType, params, JSDoc, hook, infinite }
994
994
  const isV5 = new PackageManager4().isValidSync(reactQueryDepRegex, ">=5");
995
995
  const resolvedReturnType = `${returnType} & { queryKey: TQueryKey }`;
996
996
  if (isV5) {
997
- return /* @__PURE__ */ jsx6(File6.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx6(Function4, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
997
+ return /* @__PURE__ */ jsx6(File6.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx6(Function4, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
998
998
  const { query: queryOptions, client: clientOptions = {} } = options ?? {}
999
999
  const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}
1000
1000
 
@@ -1010,7 +1010,7 @@ function Template5({ name, generics, returnType, params, JSDoc, hook, infinite }
1010
1010
 
1011
1011
  ` }) });
1012
1012
  }
1013
- return /* @__PURE__ */ jsx6(File6.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx6(Function4, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
1013
+ return /* @__PURE__ */ jsx6(File6.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx6(Function4, { name, export: true, generics, returnType: resolvedReturnType, params, JSDoc, children: `
1014
1014
  const { query: queryOptions, client: clientOptions = {} } = options ?? {}
1015
1015
  const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}
1016
1016
 
@@ -1467,4 +1467,4 @@ export {
1467
1467
  QueryOptions,
1468
1468
  Query
1469
1469
  };
1470
- //# sourceMappingURL=chunk-KF7OI5C5.js.map
1470
+ //# sourceMappingURL=chunk-ZYTZV43V.js.map