sonamu 0.7.40 → 0.7.41

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.
@@ -1 +1 @@
1
- {"version":3,"file":"generated_http.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/generated_http.template.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,wBAAyB,SAAQ,QAAQ;;IAKpD,gBAAgB;;;;IASV,MAAM;;;;;;IA8CZ,mBAAmB,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO;IAgEvE,gBAAgB,CACd,GAAG,EAAE,WAAW,EAEhB,UAAU,EAAE;QAAE,CAAC,QAAQ,EAAE,MAAM,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;KAAE,GACnD;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE;CAY9B"}
1
+ {"version":3,"file":"generated_http.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/generated_http.template.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,wBAAyB,SAAQ,QAAQ;;IAKpD,gBAAgB;;;;IASV,MAAM;;;;;;IA8CZ,mBAAmB,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO;IAiEvE,gBAAgB,CACd,GAAG,EAAE,WAAW,EAEhB,UAAU,EAAE;QAAE,CAAC,QAAQ,EAAE,MAAM,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;KAAE,GACnD;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE;CAY9B"}
@@ -63,7 +63,8 @@ export class Template__generated_http extends Template {
63
63
  return [
64
64
  this.zodTypeToReqDefault(zodType.element, name)
65
65
  ];
66
- } else if (zodType instanceof z.ZodString) {
66
+ } else if (zodType instanceof z.core.$ZodString) {
67
+ // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함
67
68
  if (name.endsWith("_at") || name.endsWith("_date") || name === "range") {
68
69
  return "2000-01-01";
69
70
  } else {
@@ -128,4 +129,4 @@ export class Template__generated_http extends Template {
128
129
  }
129
130
  }
130
131
 
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/template/implementations/generated_http.template.ts"],"sourcesContent":["import qs from \"qs\";\nimport { z } from \"zod\";\nimport { getZodObjectFromApi } from \"../../api/code-converters\";\nimport type { ExtendedApi } from \"../../api/decorators\";\nimport { Sonamu } from \"../../api/sonamu\";\nimport { Template } from \"../template\";\n\nexport class Template__generated_http extends Template {\n  constructor() {\n    super(\"generated_http\");\n  }\n\n  getTargetAndPath() {\n    const { dir } = Sonamu.config.api;\n\n    return {\n      target: `${dir}/src/application`,\n      path: `sonamu.generated.http`,\n    };\n  }\n\n  async render() {\n    const {\n      syncer: { types, apis },\n      config: {\n        api: {\n          route: { prefix },\n        },\n      },\n    } = Sonamu;\n\n    const lines = await Promise.all(\n      apis.map(async (api) => {\n        const reqObject = this.resolveApiParams(api, types);\n\n        const dataLines = await (async () => {\n          if ((api.options.httpMethod ?? \"GET\") === \"GET\") {\n            return {\n              querystring: [qs.stringify(reqObject, { encode: false }).split(\"&\").join(\"\\n\\t&\")],\n              body: [],\n            };\n          } else {\n            return {\n              querystring: [],\n              body: [\"\", JSON.stringify(reqObject, null, 2)],\n            };\n          }\n        })();\n\n        return [\n          [\n            `${api.options.httpMethod ?? \"GET\"} {{baseUrl}}${prefix}${api.path}`,\n            ...dataLines.querystring,\n          ].join(\"\\n\\t?\"),\n          `Content-Type: ${api.options.contentType ?? \"application/json\"}`,\n          ...dataLines.body,\n        ].join(\"\\n\");\n      }),\n    );\n\n    return {\n      ...this.getTargetAndPath(),\n      body: lines.join(\"\\n\\n###\\n\\n\"),\n      importKeys: [],\n    };\n  }\n\n  zodTypeToReqDefault(zodType: z.ZodType<unknown>, name: string): unknown {\n    if (zodType instanceof z.ZodObject) {\n      return Object.fromEntries(\n        Object.keys(zodType.shape).map((key) => [\n          key,\n          this.zodTypeToReqDefault(zodType.shape[key], key),\n        ]),\n      );\n    } else if (zodType instanceof z.ZodArray) {\n      return [this.zodTypeToReqDefault((zodType as z.ZodArray<z.ZodType>).element, name)];\n    } else if (zodType instanceof z.ZodString) {\n      if (name.endsWith(\"_at\") || name.endsWith(\"_date\") || name === \"range\") {\n        return \"2000-01-01\";\n      } else {\n        return name.toUpperCase();\n      }\n    } else if (zodType instanceof z.ZodNumber) {\n      if (name === \"num\") {\n        return 24;\n      }\n\n      const minValue = zodType.minValue ?? 0;\n      return minValue > Number.MIN_SAFE_INTEGER ? minValue : 0;\n    } else if (zodType instanceof z.ZodBoolean) {\n      return false;\n    } else if (zodType instanceof z.ZodEnum) {\n      return zodType.options[0];\n    } else if (zodType instanceof z.ZodOptional) {\n      return this.zodTypeToReqDefault((zodType as z.ZodOptional<z.ZodType>).def.innerType, name);\n    } else if (zodType instanceof z.ZodNullable) {\n      return null;\n    } else if (zodType instanceof z.ZodUnion) {\n      return this.zodTypeToReqDefault((zodType as z.ZodUnion<z.ZodType[]>).def.options[0], name);\n    } else if (zodType instanceof z.ZodUnknown) {\n      return \"unknown\";\n    } else if (zodType instanceof z.ZodTuple) {\n      /** biome-ignore lint/suspicious/noExplicitAny: ZodTuple 타입 사용 */\n      return zodType.def.items.map((item: any) => this.zodTypeToReqDefault(item, name));\n    } else if (zodType instanceof z.ZodDate) {\n      return \"2000-01-01\";\n    } else if (zodType instanceof z.ZodLiteral) {\n      return zodType.value;\n    } else if (zodType instanceof z.ZodRecord || zodType instanceof z.ZodMap) {\n      // biome-ignore lint/suspicious/noExplicitAny: ZodRecord 타입 사용\n      const kvDef = (zodType as z.ZodRecord<any, z.ZodType> | z.ZodMap<z.ZodType, z.ZodType>).def;\n      // biome-ignore lint/suspicious/noExplicitAny: ZodIntersection 타입 사용\n      const key = this.zodTypeToReqDefault(kvDef.keyType, name) as any;\n      const value = this.zodTypeToReqDefault(kvDef.valueType, name);\n      return { [key]: value };\n    } else if (zodType instanceof z.ZodSet) {\n      return [this.zodTypeToReqDefault((zodType as z.ZodSet<z.ZodType>).def.valueType, name)];\n    } else if (zodType instanceof z.ZodIntersection) {\n      return this.zodTypeToReqDefault(\n        (zodType as z.ZodIntersection<z.ZodType, z.ZodType>).def.right,\n        name,\n      );\n    } else if (zodType instanceof z.ZodDefault) {\n      return this.zodTypeToReqDefault((zodType as z.ZodDefault<z.ZodType>).def.innerType, name);\n    } else {\n      // console.log(zodType);\n      return `unknown-${zodType.type}`;\n    }\n  }\n\n  resolveApiParams(\n    api: ExtendedApi,\n    // biome-ignore lint/suspicious/noExplicitAny: ZodObject 타입 사용\n    references: { [typeName: string]: z.ZodObject<any> },\n  ): { [key: string]: unknown } {\n    const reqType = getZodObjectFromApi(api, references);\n    try {\n      const def = this.zodTypeToReqDefault(reqType, \"unknownName\") as {\n        [key: string]: unknown;\n      };\n      return def;\n    } catch (error) {\n      console.error(error);\n      throw new Error(`Invalid zod type detected on ${api.modelName}:${api.methodName}`);\n    }\n  }\n}\n"],"names":["qs","z","getZodObjectFromApi","Sonamu","Template","Template__generated_http","getTargetAndPath","dir","config","api","target","path","render","syncer","types","apis","route","prefix","lines","Promise","all","map","reqObject","resolveApiParams","dataLines","options","httpMethod","querystring","stringify","encode","split","join","body","JSON","contentType","importKeys","zodTypeToReqDefault","zodType","name","ZodObject","Object","fromEntries","keys","shape","key","ZodArray","element","ZodString","endsWith","toUpperCase","ZodNumber","minValue","Number","MIN_SAFE_INTEGER","ZodBoolean","ZodEnum","ZodOptional","def","innerType","ZodNullable","ZodUnion","ZodUnknown","ZodTuple","items","item","ZodDate","ZodLiteral","value","ZodRecord","ZodMap","kvDef","keyType","valueType","ZodSet","ZodIntersection","right","ZodDefault","type","references","reqType","error","console","Error","modelName","methodName"],"mappings":"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"}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/template/implementations/generated_http.template.ts"],"sourcesContent":["import qs from \"qs\";\nimport { z } from \"zod\";\nimport { getZodObjectFromApi } from \"../../api/code-converters\";\nimport type { ExtendedApi } from \"../../api/decorators\";\nimport { Sonamu } from \"../../api/sonamu\";\nimport { Template } from \"../template\";\n\nexport class Template__generated_http extends Template {\n  constructor() {\n    super(\"generated_http\");\n  }\n\n  getTargetAndPath() {\n    const { dir } = Sonamu.config.api;\n\n    return {\n      target: `${dir}/src/application`,\n      path: `sonamu.generated.http`,\n    };\n  }\n\n  async render() {\n    const {\n      syncer: { types, apis },\n      config: {\n        api: {\n          route: { prefix },\n        },\n      },\n    } = Sonamu;\n\n    const lines = await Promise.all(\n      apis.map(async (api) => {\n        const reqObject = this.resolveApiParams(api, types);\n\n        const dataLines = await (async () => {\n          if ((api.options.httpMethod ?? \"GET\") === \"GET\") {\n            return {\n              querystring: [qs.stringify(reqObject, { encode: false }).split(\"&\").join(\"\\n\\t&\")],\n              body: [],\n            };\n          } else {\n            return {\n              querystring: [],\n              body: [\"\", JSON.stringify(reqObject, null, 2)],\n            };\n          }\n        })();\n\n        return [\n          [\n            `${api.options.httpMethod ?? \"GET\"} {{baseUrl}}${prefix}${api.path}`,\n            ...dataLines.querystring,\n          ].join(\"\\n\\t?\"),\n          `Content-Type: ${api.options.contentType ?? \"application/json\"}`,\n          ...dataLines.body,\n        ].join(\"\\n\");\n      }),\n    );\n\n    return {\n      ...this.getTargetAndPath(),\n      body: lines.join(\"\\n\\n###\\n\\n\"),\n      importKeys: [],\n    };\n  }\n\n  zodTypeToReqDefault(zodType: z.ZodType<unknown>, name: string): unknown {\n    if (zodType instanceof z.ZodObject) {\n      return Object.fromEntries(\n        Object.keys(zodType.shape).map((key) => [\n          key,\n          this.zodTypeToReqDefault(zodType.shape[key], key),\n        ]),\n      );\n    } else if (zodType instanceof z.ZodArray) {\n      return [this.zodTypeToReqDefault((zodType as z.ZodArray<z.ZodType>).element, name)];\n    } else if (zodType instanceof z.core.$ZodString) {\n      // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함\n      if (name.endsWith(\"_at\") || name.endsWith(\"_date\") || name === \"range\") {\n        return \"2000-01-01\";\n      } else {\n        return name.toUpperCase();\n      }\n    } else if (zodType instanceof z.ZodNumber) {\n      if (name === \"num\") {\n        return 24;\n      }\n\n      const minValue = zodType.minValue ?? 0;\n      return minValue > Number.MIN_SAFE_INTEGER ? minValue : 0;\n    } else if (zodType instanceof z.ZodBoolean) {\n      return false;\n    } else if (zodType instanceof z.ZodEnum) {\n      return zodType.options[0];\n    } else if (zodType instanceof z.ZodOptional) {\n      return this.zodTypeToReqDefault((zodType as z.ZodOptional<z.ZodType>).def.innerType, name);\n    } else if (zodType instanceof z.ZodNullable) {\n      return null;\n    } else if (zodType instanceof z.ZodUnion) {\n      return this.zodTypeToReqDefault((zodType as z.ZodUnion<z.ZodType[]>).def.options[0], name);\n    } else if (zodType instanceof z.ZodUnknown) {\n      return \"unknown\";\n    } else if (zodType instanceof z.ZodTuple) {\n      /** biome-ignore lint/suspicious/noExplicitAny: ZodTuple 타입 사용 */\n      return zodType.def.items.map((item: any) => this.zodTypeToReqDefault(item, name));\n    } else if (zodType instanceof z.ZodDate) {\n      return \"2000-01-01\";\n    } else if (zodType instanceof z.ZodLiteral) {\n      return zodType.value;\n    } else if (zodType instanceof z.ZodRecord || zodType instanceof z.ZodMap) {\n      // biome-ignore lint/suspicious/noExplicitAny: ZodRecord 타입 사용\n      const kvDef = (zodType as z.ZodRecord<any, z.ZodType> | z.ZodMap<z.ZodType, z.ZodType>).def;\n      // biome-ignore lint/suspicious/noExplicitAny: ZodIntersection 타입 사용\n      const key = this.zodTypeToReqDefault(kvDef.keyType, name) as any;\n      const value = this.zodTypeToReqDefault(kvDef.valueType, name);\n      return { [key]: value };\n    } else if (zodType instanceof z.ZodSet) {\n      return [this.zodTypeToReqDefault((zodType as z.ZodSet<z.ZodType>).def.valueType, name)];\n    } else if (zodType instanceof z.ZodIntersection) {\n      return this.zodTypeToReqDefault(\n        (zodType as z.ZodIntersection<z.ZodType, z.ZodType>).def.right,\n        name,\n      );\n    } else if (zodType instanceof z.ZodDefault) {\n      return this.zodTypeToReqDefault((zodType as z.ZodDefault<z.ZodType>).def.innerType, name);\n    } else {\n      // console.log(zodType);\n      return `unknown-${zodType.type}`;\n    }\n  }\n\n  resolveApiParams(\n    api: ExtendedApi,\n    // biome-ignore lint/suspicious/noExplicitAny: ZodObject 타입 사용\n    references: { [typeName: string]: z.ZodObject<any> },\n  ): { [key: string]: unknown } {\n    const reqType = getZodObjectFromApi(api, references);\n    try {\n      const def = this.zodTypeToReqDefault(reqType, \"unknownName\") as {\n        [key: string]: unknown;\n      };\n      return def;\n    } catch (error) {\n      console.error(error);\n      throw new Error(`Invalid zod type detected on ${api.modelName}:${api.methodName}`);\n    }\n  }\n}\n"],"names":["qs","z","getZodObjectFromApi","Sonamu","Template","Template__generated_http","getTargetAndPath","dir","config","api","target","path","render","syncer","types","apis","route","prefix","lines","Promise","all","map","reqObject","resolveApiParams","dataLines","options","httpMethod","querystring","stringify","encode","split","join","body","JSON","contentType","importKeys","zodTypeToReqDefault","zodType","name","ZodObject","Object","fromEntries","keys","shape","key","ZodArray","element","core","$ZodString","endsWith","toUpperCase","ZodNumber","minValue","Number","MIN_SAFE_INTEGER","ZodBoolean","ZodEnum","ZodOptional","def","innerType","ZodNullable","ZodUnion","ZodUnknown","ZodTuple","items","item","ZodDate","ZodLiteral","value","ZodRecord","ZodMap","kvDef","keyType","valueType","ZodSet","ZodIntersection","right","ZodDefault","type","references","reqType","error","console","Error","modelName","methodName"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"queries.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/queries.template.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEzD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,iBAAkB,SAAQ,QAAQ;;IAK7C,gBAAgB;;;;IAQhB,MAAM,CAAC,EAAE,EAAE,eAAe,CAAC,SAAS,CAAC;;;;;;;CAwFtC"}
1
+ {"version":3,"file":"queries.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/queries.template.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEzD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,iBAAkB,SAAQ,QAAQ;;IAK7C,gBAAgB;;;;IAQhB,MAAM,CAAC,EAAE,EAAE,eAAe,CAAC,SAAS,CAAC;;;;;;;CAmGtC"}
@@ -60,11 +60,15 @@ ${functions.join("\n\n")}
60
60
  }
61
61
  `.trim());
62
62
  }
63
+ // tanstack-query API가 없으면 헬퍼 함수와 import를 포함하지 않습니다.
64
+ // 새 프로젝트에서 첫 빌드 시 sync가 아직 안 되어 namespace가 비어있을 수 있고,
65
+ // 이때 createSSRQuery가 unused로 빌드 에러가 발생하는 것을 방지합니다.
66
+ const hasQueries = namespaces.length > 0;
63
67
  return {
64
68
  ...this.getTargetAndPath(),
65
69
  body: namespaces.join("\n\n"),
66
70
  importKeys: diff(unique(importKeys), typeParamNames),
67
- customHeaders: [
71
+ customHeaders: hasQueries ? [
68
72
  "/** biome-ignore-all lint: generated는 무시 */",
69
73
  "/** biome-ignore-all assist: generated는 무시 */",
70
74
  "",
@@ -75,9 +79,13 @@ ${functions.join("\n\n")}
75
79
  ` return { modelName, methodName, params, serviceKey, __brand: 'SSRQuery' } as SSRQuery;`,
76
80
  `}`,
77
81
  ""
82
+ ] : [
83
+ "/** biome-ignore-all lint: generated는 무시 */",
84
+ "/** biome-ignore-all assist: generated는 무시 */",
85
+ ""
78
86
  ]
79
87
  };
80
88
  }
81
89
  }
82
90
 
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/template/implementations/queries.template.ts"],"sourcesContent":["import inflection from \"inflection\";\nimport { diff, unique } from \"radashi\";\nimport { apiParamToTsCode, apiParamTypeToTsType } from \"../../api/code-converters\";\nimport type { ExtendedApi } from \"../../api/decorators\";\nimport { Sonamu } from \"../../api/sonamu\";\nimport type { TemplateOptions } from \"../../types/types\";\nimport { ApiParamType } from \"../../types/types\";\nimport { Template } from \"../template\";\n\nexport class Template__queries extends Template {\n  constructor() {\n    super(\"queries\");\n  }\n\n  getTargetAndPath() {\n    const { dir } = Sonamu.config.api;\n    return {\n      target: `${dir}/src/application`,\n      path: `queries.generated.ts`,\n    };\n  }\n\n  render({}: TemplateOptions[\"queries\"]) {\n    const { apis } = Sonamu.syncer;\n\n    // tanstack-query를 포함한 API만 필터링\n    const queryApis = apis.filter((api) => api.options.clients?.includes(\"tanstack-query\"));\n\n    // 모델별로 그룹화\n    const apisByModel = new Map<string, ExtendedApi[]>();\n    for (const api of queryApis) {\n      const modelName = api.modelName.replace(/Model$/, \"\").replace(/Frame$/, \"\");\n      if (!apisByModel.has(modelName)) {\n        apisByModel.set(modelName, []);\n      }\n      apisByModel.get(modelName)?.push(api);\n    }\n\n    const namespaces: string[] = [];\n    const importKeys: string[] = [];\n    let typeParamNames: string[] = [];\n\n    for (const [modelName, modelApis] of apisByModel) {\n      const functions: string[] = [];\n\n      for (const api of modelApis) {\n        // Context 제외한 파라미터\n        const paramsWithoutContext = api.parameters.filter(\n          (param) =>\n            !ApiParamType.isContext(param.type) &&\n            !ApiParamType.isRefKnex(param.type) &&\n            !(param.optional === true && param.name.startsWith(\"_\")),\n        );\n\n        // 타입 파라미터 이름 수집\n        typeParamNames = typeParamNames.concat(api.typeParameters.map((tp) => tp.id));\n\n        // 타입 파라미터 정의\n        const typeParametersAsTsType = api.typeParameters\n          .map((typeParam) => {\n            return apiParamTypeToTsType(typeParam, importKeys);\n          })\n          .join(\", \");\n        const typeParamsDef = typeParametersAsTsType ? `<${typeParametersAsTsType}>` : \"\";\n\n        // 파라미터 정의\n        const paramsDef = apiParamToTsCode(paramsWithoutContext, importKeys);\n        const paramNames = paramsWithoutContext.map((p) => p.name).join(\", \");\n\n        // serviceMethodName 계산 (services.template.ts와 동일한 로직)\n        const serviceMethodName = api.options.resourceName\n          ? `get${inflection.camelize(api.options.resourceName)}`\n          : api.methodName;\n\n        // SSRQuery 함수 생성 (함수명도 serviceMethodName 사용)\n        functions.push(\n          `\n  export const ${serviceMethodName} = ${typeParamsDef}(${paramsDef}): SSRQuery =>\n    createSSRQuery('${api.modelName}', '${api.methodName}', [${paramNames}], ['${modelName}', '${serviceMethodName}']);\n          `.trim(),\n        );\n      }\n\n      namespaces.push(\n        `\nexport namespace ${modelName}Service {\n${functions.join(\"\\n\\n\")}\n}\n      `.trim(),\n      );\n    }\n\n    return {\n      ...this.getTargetAndPath(),\n      body: namespaces.join(\"\\n\\n\"),\n      importKeys: diff(unique(importKeys), typeParamNames),\n      customHeaders: [\n        \"/** biome-ignore-all lint: generated는 무시 */\",\n        \"/** biome-ignore-all assist: generated는 무시 */\",\n        \"\",\n        `import type { SSRQuery } from 'sonamu/ssr';`,\n        \"\",\n        `// SSRQuery 헬퍼 함수`,\n        `function createSSRQuery(modelName: string, methodName: string, params: any[], serviceKey: [string, string]): SSRQuery {`,\n        `  return { modelName, methodName, params, serviceKey, __brand: 'SSRQuery' } as SSRQuery;`,\n        `}`,\n        \"\",\n      ],\n    };\n  }\n}\n"],"names":["inflection","diff","unique","apiParamToTsCode","apiParamTypeToTsType","Sonamu","ApiParamType","Template","Template__queries","getTargetAndPath","dir","config","api","target","path","render","apis","syncer","queryApis","filter","options","clients","includes","apisByModel","Map","modelName","replace","has","set","get","push","namespaces","importKeys","typeParamNames","modelApis","functions","paramsWithoutContext","parameters","param","isContext","type","isRefKnex","optional","name","startsWith","concat","typeParameters","map","tp","id","typeParametersAsTsType","typeParam","join","typeParamsDef","paramsDef","paramNames","p","serviceMethodName","resourceName","camelize","methodName","trim","body","customHeaders"],"mappings":"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"}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/template/implementations/queries.template.ts"],"sourcesContent":["import inflection from \"inflection\";\nimport { diff, unique } from \"radashi\";\nimport { apiParamToTsCode, apiParamTypeToTsType } from \"../../api/code-converters\";\nimport type { ExtendedApi } from \"../../api/decorators\";\nimport { Sonamu } from \"../../api/sonamu\";\nimport type { TemplateOptions } from \"../../types/types\";\nimport { ApiParamType } from \"../../types/types\";\nimport { Template } from \"../template\";\n\nexport class Template__queries extends Template {\n  constructor() {\n    super(\"queries\");\n  }\n\n  getTargetAndPath() {\n    const { dir } = Sonamu.config.api;\n    return {\n      target: `${dir}/src/application`,\n      path: `queries.generated.ts`,\n    };\n  }\n\n  render({}: TemplateOptions[\"queries\"]) {\n    const { apis } = Sonamu.syncer;\n\n    // tanstack-query를 포함한 API만 필터링\n    const queryApis = apis.filter((api) => api.options.clients?.includes(\"tanstack-query\"));\n\n    // 모델별로 그룹화\n    const apisByModel = new Map<string, ExtendedApi[]>();\n    for (const api of queryApis) {\n      const modelName = api.modelName.replace(/Model$/, \"\").replace(/Frame$/, \"\");\n      if (!apisByModel.has(modelName)) {\n        apisByModel.set(modelName, []);\n      }\n      apisByModel.get(modelName)?.push(api);\n    }\n\n    const namespaces: string[] = [];\n    const importKeys: string[] = [];\n    let typeParamNames: string[] = [];\n\n    for (const [modelName, modelApis] of apisByModel) {\n      const functions: string[] = [];\n\n      for (const api of modelApis) {\n        // Context 제외한 파라미터\n        const paramsWithoutContext = api.parameters.filter(\n          (param) =>\n            !ApiParamType.isContext(param.type) &&\n            !ApiParamType.isRefKnex(param.type) &&\n            !(param.optional === true && param.name.startsWith(\"_\")),\n        );\n\n        // 타입 파라미터 이름 수집\n        typeParamNames = typeParamNames.concat(api.typeParameters.map((tp) => tp.id));\n\n        // 타입 파라미터 정의\n        const typeParametersAsTsType = api.typeParameters\n          .map((typeParam) => {\n            return apiParamTypeToTsType(typeParam, importKeys);\n          })\n          .join(\", \");\n        const typeParamsDef = typeParametersAsTsType ? `<${typeParametersAsTsType}>` : \"\";\n\n        // 파라미터 정의\n        const paramsDef = apiParamToTsCode(paramsWithoutContext, importKeys);\n        const paramNames = paramsWithoutContext.map((p) => p.name).join(\", \");\n\n        // serviceMethodName 계산 (services.template.ts와 동일한 로직)\n        const serviceMethodName = api.options.resourceName\n          ? `get${inflection.camelize(api.options.resourceName)}`\n          : api.methodName;\n\n        // SSRQuery 함수 생성 (함수명도 serviceMethodName 사용)\n        functions.push(\n          `\n  export const ${serviceMethodName} = ${typeParamsDef}(${paramsDef}): SSRQuery =>\n    createSSRQuery('${api.modelName}', '${api.methodName}', [${paramNames}], ['${modelName}', '${serviceMethodName}']);\n          `.trim(),\n        );\n      }\n\n      namespaces.push(\n        `\nexport namespace ${modelName}Service {\n${functions.join(\"\\n\\n\")}\n}\n      `.trim(),\n      );\n    }\n\n    // tanstack-query API가 없으면 헬퍼 함수와 import를 포함하지 않습니다.\n    // 새 프로젝트에서 첫 빌드 시 sync가 아직 안 되어 namespace가 비어있을 수 있고,\n    // 이때 createSSRQuery가 unused로 빌드 에러가 발생하는 것을 방지합니다.\n    const hasQueries = namespaces.length > 0;\n\n    return {\n      ...this.getTargetAndPath(),\n      body: namespaces.join(\"\\n\\n\"),\n      importKeys: diff(unique(importKeys), typeParamNames),\n      customHeaders: hasQueries\n        ? [\n            \"/** biome-ignore-all lint: generated는 무시 */\",\n            \"/** biome-ignore-all assist: generated는 무시 */\",\n            \"\",\n            `import type { SSRQuery } from 'sonamu/ssr';`,\n            \"\",\n            `// SSRQuery 헬퍼 함수`,\n            `function createSSRQuery(modelName: string, methodName: string, params: any[], serviceKey: [string, string]): SSRQuery {`,\n            `  return { modelName, methodName, params, serviceKey, __brand: 'SSRQuery' } as SSRQuery;`,\n            `}`,\n            \"\",\n          ]\n        : [\n            \"/** biome-ignore-all lint: generated는 무시 */\",\n            \"/** biome-ignore-all assist: generated는 무시 */\",\n            \"\",\n          ],\n    };\n  }\n}\n"],"names":["inflection","diff","unique","apiParamToTsCode","apiParamTypeToTsType","Sonamu","ApiParamType","Template","Template__queries","getTargetAndPath","dir","config","api","target","path","render","apis","syncer","queryApis","filter","options","clients","includes","apisByModel","Map","modelName","replace","has","set","get","push","namespaces","importKeys","typeParamNames","modelApis","functions","paramsWithoutContext","parameters","param","isContext","type","isRefKnex","optional","name","startsWith","concat","typeParameters","map","tp","id","typeParametersAsTsType","typeParam","join","typeParamsDef","paramsDef","paramNames","p","serviceMethodName","resourceName","camelize","methodName","trim","hasQueries","length","body","customHeaders"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"view_form.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/view_form.template.ts"],"names":[],"mappings":"AAGA,OAAO,EAAiB,KAAK,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AACpF,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGrF,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,mBAAoB,SAAQ,QAAQ;;IAK/C,gBAAgB,CAAC,KAAK,EAAE,iBAAiB;;;;IAOhC,mBAAmB,IAAI,MAAM,EAAE,GAAG,IAAI;IAI/C,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM;IAO5C,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM;IAI5C,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa;IAmBvD,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,iBAAiB,GAAG,MAAM;IAqEpF,mBAAmB,CAAC,OAAO,EAAE,aAAa,EAAE,GAAG,MAAM;IAmC/C,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,eAAe,CAAC,WAAW,CAAC;;;;;;;;;;CAoWxD"}
1
+ {"version":3,"file":"view_form.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/view_form.template.ts"],"names":[],"mappings":"AAGA,OAAO,EAAiB,KAAK,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AACpF,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGrF,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,mBAAoB,SAAQ,QAAQ;;IAK/C,gBAAgB,CAAC,KAAK,EAAE,iBAAiB;;;;IAOhC,mBAAmB,IAAI,MAAM,EAAE,GAAG,IAAI;IAI/C,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM;IAO5C,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM;IAI5C,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa;IAmBvD,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,iBAAiB,GAAG,MAAM;IAqEpF,mBAAmB,CAAC,OAAO,EAAE,aAAa,EAAE,GAAG,MAAM;IAqC/C,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,eAAe,CAAC,WAAW,CAAC;;;;;;;;;;CAoWxD"}
@@ -130,7 +130,9 @@ export class Template__view_form extends Template {
130
130
  value = Object.keys(col.zodType.enum)[0];
131
131
  } else if (col.zodType instanceof z.ZodBoolean) {
132
132
  value = false;
133
- } else if (col.zodType instanceof z.ZodString) {
133
+ } else if (col.zodType instanceof z.core.$ZodString) {
134
+ // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함
135
+ // FIXME: email이나 url 타입 등에 대한 처리가 필요함
134
136
  if (col.renderType === "string-datetime") {
135
137
  value = "now()";
136
138
  } else {
@@ -476,4 +478,4 @@ ${columns.filter((col)=>col.name !== "created_at").map((col)=>{
476
478
  }
477
479
  }
478
480
 
479
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/template/implementations/view_form.template.ts"],"sourcesContent":["import inflection from \"inflection\";\nimport { unique } from \"radashi\";\nimport { z } from \"zod\";\nimport { EntityManager, type EntityNamesRecord } from \"../../entity/entity-manager\";\nimport type { RenderingNode, TemplateKey, TemplateOptions } from \"../../types/types\";\nimport { getEnumInfoFromColName, getRelationPropFromColName } from \"../helpers\";\nimport type { RenderedTemplate } from \"../template\";\nimport { Template } from \"../template\";\n\nexport class Template__view_form extends Template {\n  constructor() {\n    super(\"view_form\");\n  }\n\n  getTargetAndPath(names: EntityNamesRecord) {\n    return {\n      target: \"web/src/routes/admin\",\n      path: `${names.fsPlural}/form.tsx`,\n    };\n  }\n\n  override getRequiredDictKeys(): string[] | null {\n    return [\"entity.create\", \"entity.edit\", \"common.backToList\", \"form.createdAt\", \"common.save\"];\n  }\n\n  wrapFC(body: string, label?: string): string {\n    return [\n      `<div className=\"space-y-2\">${label ? `\\n  <Label>${label}</Label>` : \"\"}`,\n      `  ${body}`,\n      `</div>`,\n    ].join(\"\\n\");\n  }\n  wrapFG(body: string, label?: string): string {\n    return this.wrapFC(body, label);\n  }\n\n  renderColumnImport(entityId: string, col: RenderingNode) {\n    if (col.renderType === \"enums\") {\n      const { id, targetEntityNames } = getEnumInfoFromColName(entityId, col.name);\n      const componentId = `${id}Select`;\n      return `import { ${componentId} } from \"@/components/${targetEntityNames.fs}/${componentId}\";`;\n    } else if (col.renderType === \"number-fk_id\") {\n      try {\n        const relProp = getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n        const targetNames = EntityManager.getNamesFromId(relProp.with);\n        const componentId = `${relProp.with}IdAsyncSelect`;\n        return `import { ${componentId} } from \"@/components/${targetNames.fs}/${componentId}\";`;\n      } catch {\n        return \"\";\n      }\n    } else {\n      throw new Error(`렌더 불가능한 임포트 ${col.name} ${col.renderType}`);\n    }\n  }\n\n  renderColumn(entityId: string, col: RenderingNode, names: EntityNamesRecord): string {\n    const regExpr = `{...register(\"${col.name}\")}`;\n    const placeholder = `{SD(\"entity.${entityId}.${col.name}\")}`;\n\n    switch (col.renderType) {\n      case \"string-plain\":\n        if (col.zodType instanceof z.ZodString && (col.zodType.maxLength ?? 0) <= 256) {\n          return `<Input className=\"h-8 text-xs bg-white\" placeholder=${placeholder} ${regExpr} />`;\n        } else {\n          return `<Textarea className=\"text-xs bg-white\" rows={4} placeholder=${placeholder} ${regExpr} />`;\n        }\n      case \"datetime\":\n        return `<DateInput\n                    className=\"h-8 text-xs bg-white\"\n                    ${regExpr}\n                  />`;\n      case \"number-id\":\n        return `<input type=\"hidden\" ${regExpr} />`;\n      case \"number-plain\":\n        return `<Input type=\"number\" className=\"h-8 text-xs bg-white\" placeholder=${placeholder} ${regExpr} />`;\n      case \"boolean\":\n        return `<Switch ${regExpr} />`;\n      case \"json-sonamufile\":\n        return `<FileInput\n                    uploadMode=\"lazy\"\n                    viewMode=\"image\"\n                    previewSize=\"md\"\n                    ${regExpr}\n                  />`;\n      case \"json-sonamufile-array\":\n        return `<FileInput\n                    multiple={true}\n                    uploadMode=\"lazy\"\n                    viewMode=\"image\"\n                    previewSize=\"md\"\n                    maxFiles={10}\n                    ${regExpr}\n                  />`;\n      case \"enums\":\n        try {\n          let enumId: string;\n          if (col.name === \"orderBy\") {\n            enumId = `${names.capital}${inflection.camelize(col.name)}Select`;\n          } else {\n            const { id } = getEnumInfoFromColName(entityId, col.name);\n            enumId = `${id}Select`;\n          }\n          return `<${enumId} ${regExpr} ${col.optional || col.nullable ? \"clearable\" : \"\"} />`;\n        } catch {\n          return `<Input className=\"h-8 text-xs bg-white\" ${regExpr} />`;\n        }\n      case \"number-fk_id\":\n        try {\n          const relProp = getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n          const fkId = `${relProp.with}IdAsyncSelect`;\n          return `<${fkId} subset=\"A\" ${regExpr} ${\n            col.optional || col.nullable ? \"clearable\" : \"\"\n          } className=\"h-8 text-xs\" />`;\n        } catch {\n          return `<Input type=\"number\" className=\"h-8 text-xs bg-white\" placeholder=${placeholder} ${regExpr} />`;\n        }\n      case \"array\":\n      case \"object\":\n        return `<Input className=\"h-8 text-xs bg-white\" placeholder=\"${col.name}\" ${regExpr} />`;\n      default:\n        return `<Input className=\"h-8 text-xs bg-white\" ${regExpr} />`;\n    }\n  }\n\n  resolveDefaultValue(columns: RenderingNode[]): object {\n    return columns.reduce(\n      (result, col) => {\n        if (col.optional) {\n          return result;\n        }\n\n        let value: unknown;\n        if (col.nullable === true) {\n          value = null;\n        } else if (col.zodType instanceof z.ZodNumber) {\n          value = 0;\n        } else if (col.zodType instanceof z.ZodEnum) {\n          value = Object.keys(col.zodType.enum)[0];\n        } else if (col.zodType instanceof z.ZodBoolean) {\n          value = false;\n        } else if (col.zodType instanceof z.ZodString) {\n          if (col.renderType === \"string-datetime\") {\n            value = \"now()\";\n          } else {\n            value = \"\";\n          }\n        } else if (col.zodType instanceof z.ZodArray) {\n          value = [];\n        } else if (col.zodType instanceof z.ZodObject) {\n          value = {};\n        }\n\n        result[col.name] = value;\n        return result;\n      },\n      {} as { [key: string]: unknown },\n    );\n  }\n\n  async render({ entityId }: TemplateOptions[\"view_form\"]) {\n    const entity = EntityManager.get(entityId);\n    const names = EntityManager.getNamesFromId(entityId);\n\n    // SaveParams 타입을 로드하여 saveParamsNode 생성\n    const { loadTypes } = await import(\"../../syncer/module-loader\");\n    const loadedTypes = await loadTypes();\n    const SaveParamsZodType = loadedTypes[`${entityId}SaveParams`];\n\n    if (!SaveParamsZodType) {\n      throw new Error(`SaveParams for ${entityId} not found. Did you run 'sonamu sync'?`);\n    }\n\n    // Zod 타입을 RenderingNode로 변환\n    const { zodTypeToRenderingNode } = await import(\"../zod-converter\");\n    const saveParamsNode = zodTypeToRenderingNode(SaveParamsZodType);\n\n    const columns = ((saveParamsNode?.children ?? []) as RenderingNode[])\n      .filter((col) => col.name !== \"id\")\n      .map((col) => {\n        const propCandidate = entity.props.find((prop) => prop.name === col.name);\n        col.label = propCandidate?.desc ?? col.label;\n        return col;\n      });\n\n    const defaultValue = this.resolveDefaultValue(columns);\n\n    // 프리 템플릿\n    const preTemplates: RenderedTemplate[\"preTemplates\"] = (columns as RenderingNode[])\n      .filter((col) => {\n        if (col.name === \"id\") {\n          return false;\n        } else if (col.name.endsWith(\"_id\") || col.renderType === \"number-id\") {\n          try {\n            getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n            return true;\n          } catch {\n            return false;\n          }\n        } else if (col.renderType === \"enums\") {\n          try {\n            getEnumInfoFromColName(entityId, col.name);\n            return true;\n          } catch {\n            return false;\n          }\n        }\n        return false;\n      })\n      .map((col) => {\n        let key: TemplateKey;\n        let targetMdId = entityId;\n        let enumId: string | undefined;\n        if (col.renderType === \"enums\") {\n          key = \"view_enums_select\";\n          const { targetEntityNames: targetMDNames, id } = getEnumInfoFromColName(\n            entityId,\n            col.name,\n          );\n          targetMdId = targetMDNames.capital;\n          enumId = id;\n        } else {\n          key = \"view_id_async_select\";\n          const relProp = getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n          targetMdId = relProp.with;\n        }\n\n        return {\n          key: key as TemplateKey,\n          options: {\n            entityId: targetMdId,\n            node: col,\n            enumId,\n          },\n        };\n      })\n      .filter((preTemplate) => {\n        if (preTemplate.key === \"view_id_async_select\") {\n          try {\n            EntityManager.get(preTemplate.options.entityId);\n            return true;\n          } catch {\n            return false;\n          }\n        }\n        return true;\n      });\n\n    return {\n      ...this.getTargetAndPath(names),\n      body: `\nimport {\n  Button,\n  Card,\n  CardContent,\n  CardHeader,\n  CardTitle,\n  Input,${columns.some((col) => col.renderType === \"string-plain\" && col.zodType instanceof z.ZodString && (col.zodType.maxLength ?? 0) > 256) ? \"\\n  Textarea,\" : \"\"}${columns.some((col) => col.renderType === \"enums\") ? \"\\n  Select,\\n  SelectContent,\\n  SelectItem,\\n  SelectTrigger,\\n  SelectValue,\" : \"\"}${columns.some((col) => col.renderType === \"boolean\") ? \"\\n  Switch,\" : \"\"}${columns.some((col) => [\"json-sonamufile\", \"json-sonamufile-array\"].includes(col.renderType)) ? \"\\n  FileInput,\" : \"\"}${columns.some((col) => [\"string-datetime\", \"string-date\", \"datetime\"].includes(col.renderType)) ? \"\\n  DateInput,\" : \"\"}\n} from \"@sonamu-kit/react-components/components\";\nimport { useTypeForm } from \"@sonamu-kit/react-components/lib\";\nimport { useQueryClient } from \"@tanstack/react-query\";\nimport { createFileRoute, useRouter } from \"@tanstack/react-router\";\nimport { useEffect } from \"react\";\nimport { z } from \"zod\";\nimport { ${names.capital}Service } from \"@/services/services.generated\";\nimport type { ${names.capital}SubsetA } from \"@/services/sonamu.generated\";${\n        columns.filter((col) => col.renderType === \"enums\").length > 0\n          ? \"\\nimport { \" +\n            unique(\n              columns\n                .filter((col) => col.renderType === \"enums\")\n                .map((col) => {\n                  try {\n                    const { id } = getEnumInfoFromColName(entityId, col.name);\n                    return `${id}, ${id}Label`;\n                  } catch {\n                    return \"\";\n                  }\n                }),\n            )\n              .filter(Boolean)\n              .join(\", \") +\n            ' } from \"@/services/sonamu.generated\";'\n          : \"\"\n      }\nimport { defaultCatch } from \"@/services/sonamu.shared\";\nimport { ${names.capital}SaveParams } from \"@/services/${names.fs}/${names.fs}.types\";\n${unique(\n  columns\n    .filter((col) => [\"number-fk_id\", \"enums\"].includes(col.renderType))\n    .map((col) => {\n      return this.renderColumnImport(entityId, col);\n    }),\n).join(\"\\n\")}\nimport { SD } from \"@/i18n/sd.generated\";\n\nimport ArrowLeftIcon from \"~icons/lucide/arrow-left\";\nimport SaveIcon from \"~icons/lucide/save\";\nimport FormIcon from \"~icons/mdi/form-select\";\n\nconst formSearchSchema = z.object({\n  id: z.number().optional(),\n});\n\nexport const Route = createFileRoute(\"/admin/${names.fsPlural}/form\")({\n  validateSearch: formSearchSchema,\n  component: ${names.capitalPlural}FormPage,\n});\n\nfunction ${names.capitalPlural}FormPage() {\n  const { id } = Route.useSearch();\n  return <${names.capitalPlural}Form id={id} />;\n}\n\ntype ${names.capitalPlural}FormProps = {\n  id?: number;\n  mode?: \"page\" | \"modal\";\n};\n\nexport function ${names.capitalPlural}Form({ id, mode }: ${names.capitalPlural}FormProps) {\n  const router = useRouter();\n  const queryClient = useQueryClient();\n\n  const { form, setForm, register${columns.some((col) => [\"json-sonamufile\", \"json-sonamufile-array\"].includes(col.renderType)) ? \", submit\" : \"\"} } = useTypeForm(${names.capital}SaveParams, ${JSON.stringify(defaultValue).replace(/\"now\\(\\)\"/g, '\"\"')});\n${(() => {\n  const hasDatetime = columns.some((col) => col.renderType === \"string-datetime\");\n  const hasDate = columns.some((col) => col.renderType === \"string-date\");\n  if (!hasDatetime && !hasDate) return \"\";\n\n  let helpers = \"\\n\";\n  if (hasDatetime) {\n    helpers += `  // datetime-local 형식으로 변환 (YYYY-MM-DDTHH:MM)\n  const toDatetimeLocalString = (date: Date | string | null | undefined): string => {\n    if (!date) return \"\";\n    const d = typeof date === \"string\" ? new Date(date) : date;\n    return d.toISOString().slice(0, 16);\n  };\n\n  // datetime-local 문자열을 Date로 변환\n  const fromDatetimeLocalString = (value: string): Date | null => {\n    if (!value) return null;\n    return new Date(value);\n  };\n`;\n  }\n  if (hasDate) {\n    helpers += `  // date 형식으로 변환 (YYYY-MM-DD)\n  const toDateString = (date: Date | string | null | undefined): string => {\n    if (!date) return \"\";\n    const d = typeof date === \"string\" ? new Date(date) : date;\n    return d.toISOString().split(\"T\")[0];\n  };\n\n  // date 문자열을 Date로 변환\n  const fromDateString = (value: string): Date | null => {\n    if (!value) return null;\n    return new Date(value);\n  };\n`;\n  }\n  return helpers;\n})()}\n  useEffect(() => {\n    if (id) {\n      ${names.capital}Service.get${names.capital}(\"A\", id).then((row) => {\n        setForm((prevForm) => ({\n          ...prevForm,\n          ...row,${(() => {\n            // relation 필드들을 찾아서 변환 코드 생성\n            const relationFields = columns\n              .filter((col) => col.renderType === \"number-fk_id\")\n              .map((col) => {\n                const relationName = col.name.replace(/_id$/, \"\");\n                if (col.nullable) {\n                  return `\\n          ${col.name}: row.${relationName}?.id ?? null,`;\n                } else {\n                  return `\\n          ${col.name}: row.${relationName}?.id,`;\n                }\n              })\n              .join(\"\");\n            return relationFields;\n          })()}\n        }));\n      });\n    }\n  }, [id, setForm]);\n\n  const saveMutation = ${names.capital}Service.useSaveMutation();\n  const handleSubmit = ${\n    columns.some((col) => [\"json-sonamufile\", \"json-sonamufile-array\"].includes(col.renderType))\n      ? `submit(async (form) => {\n    saveMutation.mutate(\n      { spa: [form] },\n      {\n        onSuccess: () => {\n          queryClient.invalidateQueries({\n            queryKey: [\"${names.capital}\"],\n          });\n\n          if (mode === \"modal\") {\n            // modal mode\n          } else {\n            router.navigate({ to: \"/admin/${names.fsPlural}\" });\n          }\n        },\n        onError: defaultCatch,\n      },\n    );\n  })`\n      : `() => {\n    saveMutation.mutate(\n      { spa: [form] },\n      {\n        onSuccess: () => {\n          queryClient.invalidateQueries({\n            queryKey: [\"${names.capital}\"],\n          });\n\n          if (mode === \"modal\") {\n            // modal mode\n          } else {\n            router.navigate({ to: \"/admin/${names.fsPlural}\" });\n          }\n        },\n        onError: defaultCatch,\n      },\n    );\n  }`\n  };\n\n  const PAGE = {\n    title: id ? SD(\"entity.edit\")(SD(\"entity.${entityId}\"), id) : SD(\"entity.create\")(SD(\"entity.${entityId}\")),\n  };\n\n  return (\n    <div className=\"flex-1 overflow-auto\">\n      <div className=\"max-w-[1800px] mx-auto p-8\">\n        <div className=\"space-y-6 mb-8\">\n          {/* Header */}\n          <div className=\"flex items-center justify-between\">\n            <div className=\"flex items-center gap-2\">\n              <FormIcon className=\"h-5 w-5\" />\n              <span className=\"text-lg font-semibold h-5\">{PAGE.title}</span>\n            </div>\n            {mode !== \"modal\" && (\n              <Button\n                variant=\"outline\"\n                onClick={() => router.navigate({ to: \"/admin/${names.fsPlural}\" })}\n                icon={<ArrowLeftIcon />}\n              >\n                {SD(\"common.backToList\")}\n              </Button>\n            )}\n          </div>\n\n          {/* Form Card */}\n          <Card className=\"border-border/40 bg-gray-50 shadow-sm\">\n            <CardHeader className=\"px-4 border-b border-gray-200 flex items-center\">\n              <CardTitle className=\"text-sm font-medium leading-none m-0\">\n                {PAGE.title}\n              </CardTitle>\n            </CardHeader>\n            <CardContent className=\"p-6\">\n              <div className=\"space-y-6\">\n${columns\n  .filter((col) => col.name !== \"created_at\")\n  .map((col) => {\n    const label = (() => {\n      if (col.label.endsWith(\"Id\")) {\n        try {\n          const entity = EntityManager.get(col.label.replace(\"Id\", \"\"));\n          return entity.title ?? col.label;\n        } catch {\n          return col.label;\n        }\n      }\n      return col.label;\n    })();\n    return `                {/* ${label} */}\n                <div className=\"space-y-2\">\n                  <label className=\"block text-xs mb-1 text-gray-600\">{SD(\"entity.${entityId}.${col.name}\")}</label>\n                  ${this.renderColumn(entityId, col, names)}\n                </div>`;\n  })\n  .join(\"\\n\\n\")}\n\n                {/* Save Button */}\n                <div className=\"flex items-center justify-between pt-4\">\n                  {form.id && form.created_at && (\n                    <div className=\"flex items-center\">\n                      <label className=\"mr-2 text-xs text-gray-600\">{SD(\"form.createdAt\")}:</label>\n                      <span className=\"text-xs text-gray-600\">\n                        {String(form.created_at)}\n                      </span>\n                    </div>\n                  )}\n                  <Button\n                    onClick={handleSubmit}\n                    icon={<SaveIcon />}\n                  >\n                    {SD(\"common.save\")}\n                  </Button>\n                </div>\n              </div>\n            </CardContent>\n          </Card>\n        </div>\n      </div>\n    </div>\n  );\n}\n      `.trim(),\n      importKeys: [],\n      preTemplates,\n    };\n  }\n}\n"],"names":["inflection","unique","z","EntityManager","getEnumInfoFromColName","getRelationPropFromColName","Template","Template__view_form","getTargetAndPath","names","target","path","fsPlural","getRequiredDictKeys","wrapFC","body","label","join","wrapFG","renderColumnImport","entityId","col","renderType","id","targetEntityNames","name","componentId","fs","relProp","replace","targetNames","getNamesFromId","with","Error","renderColumn","regExpr","placeholder","zodType","ZodString","maxLength","enumId","capital","camelize","optional","nullable","fkId","resolveDefaultValue","columns","reduce","result","value","ZodNumber","ZodEnum","Object","keys","enum","ZodBoolean","ZodArray","ZodObject","render","entity","get","loadTypes","loadedTypes","SaveParamsZodType","zodTypeToRenderingNode","saveParamsNode","children","filter","map","propCandidate","props","find","prop","desc","defaultValue","preTemplates","endsWith","key","targetMdId","targetMDNames","options","node","preTemplate","some","includes","length","Boolean","capitalPlural","JSON","stringify","hasDatetime","hasDate","helpers","relationFields","relationName","title","trim","importKeys"],"mappings":"AAAA,OAAOA,gBAAgB,aAAa;AACpC,SAASC,MAAM,QAAQ,UAAU;AACjC,SAASC,CAAC,QAAQ,MAAM;AACxB,SAASC,aAAa,QAAgC,iCAA8B;AAEpF,SAASC,sBAAsB,EAAEC,0BAA0B,QAAQ,gBAAa;AAEhF,SAASC,QAAQ,QAAQ,iBAAc;AAEvC,OAAO,MAAMC,4BAA4BD;IACvC,aAAc;QACZ,KAAK,CAAC;IACR;IAEAE,iBAAiBC,KAAwB,EAAE;QACzC,OAAO;YACLC,QAAQ;YACRC,MAAM,GAAGF,MAAMG,QAAQ,CAAC,SAAS,CAAC;QACpC;IACF;IAESC,sBAAuC;QAC9C,OAAO;YAAC;YAAiB;YAAe;YAAqB;YAAkB;SAAc;IAC/F;IAEAC,OAAOC,IAAY,EAAEC,KAAc,EAAU;QAC3C,OAAO;YACL,CAAC,2BAA2B,EAAEA,QAAQ,CAAC,WAAW,EAAEA,MAAM,QAAQ,CAAC,GAAG,IAAI;YAC1E,CAAC,EAAE,EAAED,MAAM;YACX,CAAC,MAAM,CAAC;SACT,CAACE,IAAI,CAAC;IACT;IACAC,OAAOH,IAAY,EAAEC,KAAc,EAAU;QAC3C,OAAO,IAAI,CAACF,MAAM,CAACC,MAAMC;IAC3B;IAEAG,mBAAmBC,QAAgB,EAAEC,GAAkB,EAAE;QACvD,IAAIA,IAAIC,UAAU,KAAK,SAAS;YAC9B,MAAM,EAAEC,EAAE,EAAEC,iBAAiB,EAAE,GAAGpB,uBAAuBgB,UAAUC,IAAII,IAAI;YAC3E,MAAMC,cAAc,GAAGH,GAAG,MAAM,CAAC;YACjC,OAAO,CAAC,SAAS,EAAEG,YAAY,sBAAsB,EAAEF,kBAAkBG,EAAE,CAAC,CAAC,EAAED,YAAY,EAAE,CAAC;QAChG,OAAO,IAAIL,IAAIC,UAAU,KAAK,gBAAgB;YAC5C,IAAI;gBACF,MAAMM,UAAUvB,2BAA2Be,UAAUC,IAAII,IAAI,CAACI,OAAO,CAAC,OAAO;gBAC7E,MAAMC,cAAc3B,cAAc4B,cAAc,CAACH,QAAQI,IAAI;gBAC7D,MAAMN,cAAc,GAAGE,QAAQI,IAAI,CAAC,aAAa,CAAC;gBAClD,OAAO,CAAC,SAAS,EAAEN,YAAY,sBAAsB,EAAEI,YAAYH,EAAE,CAAC,CAAC,EAAED,YAAY,EAAE,CAAC;YAC1F,EAAE,OAAM;gBACN,OAAO;YACT;QACF,OAAO;YACL,MAAM,IAAIO,MAAM,CAAC,YAAY,EAAEZ,IAAII,IAAI,CAAC,CAAC,EAAEJ,IAAIC,UAAU,EAAE;QAC7D;IACF;IAEAY,aAAad,QAAgB,EAAEC,GAAkB,EAAEZ,KAAwB,EAAU;QACnF,MAAM0B,UAAU,CAAC,cAAc,EAAEd,IAAII,IAAI,CAAC,GAAG,CAAC;QAC9C,MAAMW,cAAc,CAAC,YAAY,EAAEhB,SAAS,CAAC,EAAEC,IAAII,IAAI,CAAC,GAAG,CAAC;QAE5D,OAAQJ,IAAIC,UAAU;YACpB,KAAK;gBACH,IAAID,IAAIgB,OAAO,YAAYnC,EAAEoC,SAAS,IAAI,AAACjB,CAAAA,IAAIgB,OAAO,CAACE,SAAS,IAAI,CAAA,KAAM,KAAK;oBAC7E,OAAO,CAAC,oDAAoD,EAAEH,YAAY,CAAC,EAAED,QAAQ,GAAG,CAAC;gBAC3F,OAAO;oBACL,OAAO,CAAC,4DAA4D,EAAEC,YAAY,CAAC,EAAED,QAAQ,GAAG,CAAC;gBACnG;YACF,KAAK;gBACH,OAAO,CAAC;;oBAEI,EAAEA,QAAQ;oBACV,CAAC;YACf,KAAK;gBACH,OAAO,CAAC,qBAAqB,EAAEA,QAAQ,GAAG,CAAC;YAC7C,KAAK;gBACH,OAAO,CAAC,kEAAkE,EAAEC,YAAY,CAAC,EAAED,QAAQ,GAAG,CAAC;YACzG,KAAK;gBACH,OAAO,CAAC,QAAQ,EAAEA,QAAQ,GAAG,CAAC;YAChC,KAAK;gBACH,OAAO,CAAC;;;;oBAII,EAAEA,QAAQ;oBACV,CAAC;YACf,KAAK;gBACH,OAAO,CAAC;;;;;;oBAMI,EAAEA,QAAQ;oBACV,CAAC;YACf,KAAK;gBACH,IAAI;oBACF,IAAIK;oBACJ,IAAInB,IAAII,IAAI,KAAK,WAAW;wBAC1Be,SAAS,GAAG/B,MAAMgC,OAAO,GAAGzC,WAAW0C,QAAQ,CAACrB,IAAII,IAAI,EAAE,MAAM,CAAC;oBACnE,OAAO;wBACL,MAAM,EAAEF,EAAE,EAAE,GAAGnB,uBAAuBgB,UAAUC,IAAII,IAAI;wBACxDe,SAAS,GAAGjB,GAAG,MAAM,CAAC;oBACxB;oBACA,OAAO,CAAC,CAAC,EAAEiB,OAAO,CAAC,EAAEL,QAAQ,CAAC,EAAEd,IAAIsB,QAAQ,IAAItB,IAAIuB,QAAQ,GAAG,cAAc,GAAG,GAAG,CAAC;gBACtF,EAAE,OAAM;oBACN,OAAO,CAAC,wCAAwC,EAAET,QAAQ,GAAG,CAAC;gBAChE;YACF,KAAK;gBACH,IAAI;oBACF,MAAMP,UAAUvB,2BAA2Be,UAAUC,IAAII,IAAI,CAACI,OAAO,CAAC,OAAO;oBAC7E,MAAMgB,OAAO,GAAGjB,QAAQI,IAAI,CAAC,aAAa,CAAC;oBAC3C,OAAO,CAAC,CAAC,EAAEa,KAAK,YAAY,EAAEV,QAAQ,CAAC,EACrCd,IAAIsB,QAAQ,IAAItB,IAAIuB,QAAQ,GAAG,cAAc,GAC9C,2BAA2B,CAAC;gBAC/B,EAAE,OAAM;oBACN,OAAO,CAAC,kEAAkE,EAAER,YAAY,CAAC,EAAED,QAAQ,GAAG,CAAC;gBACzG;YACF,KAAK;YACL,KAAK;gBACH,OAAO,CAAC,qDAAqD,EAAEd,IAAII,IAAI,CAAC,EAAE,EAAEU,QAAQ,GAAG,CAAC;YAC1F;gBACE,OAAO,CAAC,wCAAwC,EAAEA,QAAQ,GAAG,CAAC;QAClE;IACF;IAEAW,oBAAoBC,OAAwB,EAAU;QACpD,OAAOA,QAAQC,MAAM,CACnB,CAACC,QAAQ5B;YACP,IAAIA,IAAIsB,QAAQ,EAAE;gBAChB,OAAOM;YACT;YAEA,IAAIC;YACJ,IAAI7B,IAAIuB,QAAQ,KAAK,MAAM;gBACzBM,QAAQ;YACV,OAAO,IAAI7B,IAAIgB,OAAO,YAAYnC,EAAEiD,SAAS,EAAE;gBAC7CD,QAAQ;YACV,OAAO,IAAI7B,IAAIgB,OAAO,YAAYnC,EAAEkD,OAAO,EAAE;gBAC3CF,QAAQG,OAAOC,IAAI,CAACjC,IAAIgB,OAAO,CAACkB,IAAI,CAAC,CAAC,EAAE;YAC1C,OAAO,IAAIlC,IAAIgB,OAAO,YAAYnC,EAAEsD,UAAU,EAAE;gBAC9CN,QAAQ;YACV,OAAO,IAAI7B,IAAIgB,OAAO,YAAYnC,EAAEoC,SAAS,EAAE;gBAC7C,IAAIjB,IAAIC,UAAU,KAAK,mBAAmB;oBACxC4B,QAAQ;gBACV,OAAO;oBACLA,QAAQ;gBACV;YACF,OAAO,IAAI7B,IAAIgB,OAAO,YAAYnC,EAAEuD,QAAQ,EAAE;gBAC5CP,QAAQ,EAAE;YACZ,OAAO,IAAI7B,IAAIgB,OAAO,YAAYnC,EAAEwD,SAAS,EAAE;gBAC7CR,QAAQ,CAAC;YACX;YAEAD,MAAM,CAAC5B,IAAII,IAAI,CAAC,GAAGyB;YACnB,OAAOD;QACT,GACA,CAAC;IAEL;IAEA,MAAMU,OAAO,EAAEvC,QAAQ,EAAgC,EAAE;QACvD,MAAMwC,SAASzD,cAAc0D,GAAG,CAACzC;QACjC,MAAMX,QAAQN,cAAc4B,cAAc,CAACX;QAE3C,wCAAwC;QACxC,MAAM,EAAE0C,SAAS,EAAE,GAAG,MAAM,MAAM,CAAC;QACnC,MAAMC,cAAc,MAAMD;QAC1B,MAAME,oBAAoBD,WAAW,CAAC,GAAG3C,SAAS,UAAU,CAAC,CAAC;QAE9D,IAAI,CAAC4C,mBAAmB;YACtB,MAAM,IAAI/B,MAAM,CAAC,eAAe,EAAEb,SAAS,sCAAsC,CAAC;QACpF;QAEA,4BAA4B;QAC5B,MAAM,EAAE6C,sBAAsB,EAAE,GAAG,MAAM,MAAM,CAAC;QAChD,MAAMC,iBAAiBD,uBAAuBD;QAE9C,MAAMjB,UAAU,AAAEmB,CAAAA,gBAAgBC,YAAY,EAAE,AAAD,EAC5CC,MAAM,CAAC,CAAC/C,MAAQA,IAAII,IAAI,KAAK,MAC7B4C,GAAG,CAAC,CAAChD;YACJ,MAAMiD,gBAAgBV,OAAOW,KAAK,CAACC,IAAI,CAAC,CAACC,OAASA,KAAKhD,IAAI,KAAKJ,IAAII,IAAI;YACxEJ,IAAIL,KAAK,GAAGsD,eAAeI,QAAQrD,IAAIL,KAAK;YAC5C,OAAOK;QACT;QAEF,MAAMsD,eAAe,IAAI,CAAC7B,mBAAmB,CAACC;QAE9C,SAAS;QACT,MAAM6B,eAAiD,AAAC7B,QACrDqB,MAAM,CAAC,CAAC/C;YACP,IAAIA,IAAII,IAAI,KAAK,MAAM;gBACrB,OAAO;YACT,OAAO,IAAIJ,IAAII,IAAI,CAACoD,QAAQ,CAAC,UAAUxD,IAAIC,UAAU,KAAK,aAAa;gBACrE,IAAI;oBACFjB,2BAA2Be,UAAUC,IAAII,IAAI,CAACI,OAAO,CAAC,OAAO;oBAC7D,OAAO;gBACT,EAAE,OAAM;oBACN,OAAO;gBACT;YACF,OAAO,IAAIR,IAAIC,UAAU,KAAK,SAAS;gBACrC,IAAI;oBACFlB,uBAAuBgB,UAAUC,IAAII,IAAI;oBACzC,OAAO;gBACT,EAAE,OAAM;oBACN,OAAO;gBACT;YACF;YACA,OAAO;QACT,GACC4C,GAAG,CAAC,CAAChD;YACJ,IAAIyD;YACJ,IAAIC,aAAa3D;YACjB,IAAIoB;YACJ,IAAInB,IAAIC,UAAU,KAAK,SAAS;gBAC9BwD,MAAM;gBACN,MAAM,EAAEtD,mBAAmBwD,aAAa,EAAEzD,EAAE,EAAE,GAAGnB,uBAC/CgB,UACAC,IAAII,IAAI;gBAEVsD,aAAaC,cAAcvC,OAAO;gBAClCD,SAASjB;YACX,OAAO;gBACLuD,MAAM;gBACN,MAAMlD,UAAUvB,2BAA2Be,UAAUC,IAAII,IAAI,CAACI,OAAO,CAAC,OAAO;gBAC7EkD,aAAanD,QAAQI,IAAI;YAC3B;YAEA,OAAO;gBACL8C,KAAKA;gBACLG,SAAS;oBACP7D,UAAU2D;oBACVG,MAAM7D;oBACNmB;gBACF;YACF;QACF,GACC4B,MAAM,CAAC,CAACe;YACP,IAAIA,YAAYL,GAAG,KAAK,wBAAwB;gBAC9C,IAAI;oBACF3E,cAAc0D,GAAG,CAACsB,YAAYF,OAAO,CAAC7D,QAAQ;oBAC9C,OAAO;gBACT,EAAE,OAAM;oBACN,OAAO;gBACT;YACF;YACA,OAAO;QACT;QAEF,OAAO;YACL,GAAG,IAAI,CAACZ,gBAAgB,CAACC,MAAM;YAC/BM,MAAM,CAAC;;;;;;;QAOL,EAAEgC,QAAQqC,IAAI,CAAC,CAAC/D,MAAQA,IAAIC,UAAU,KAAK,kBAAkBD,IAAIgB,OAAO,YAAYnC,EAAEoC,SAAS,IAAI,AAACjB,CAAAA,IAAIgB,OAAO,CAACE,SAAS,IAAI,CAAA,IAAK,OAAO,kBAAkB,KAAKQ,QAAQqC,IAAI,CAAC,CAAC/D,MAAQA,IAAIC,UAAU,KAAK,WAAW,mFAAmF,KAAKyB,QAAQqC,IAAI,CAAC,CAAC/D,MAAQA,IAAIC,UAAU,KAAK,aAAa,gBAAgB,KAAKyB,QAAQqC,IAAI,CAAC,CAAC/D,MAAQ;oBAAC;oBAAmB;iBAAwB,CAACgE,QAAQ,CAAChE,IAAIC,UAAU,KAAK,mBAAmB,KAAKyB,QAAQqC,IAAI,CAAC,CAAC/D,MAAQ;oBAAC;oBAAmB;oBAAe;iBAAW,CAACgE,QAAQ,CAAChE,IAAIC,UAAU,KAAK,mBAAmB,GAAG;;;;;;;SAOpmB,EAAEb,MAAMgC,OAAO,CAAC;cACX,EAAEhC,MAAMgC,OAAO,CAAC,6CAA6C,EACnEM,QAAQqB,MAAM,CAAC,CAAC/C,MAAQA,IAAIC,UAAU,KAAK,SAASgE,MAAM,GAAG,IACzD,gBACArF,OACE8C,QACGqB,MAAM,CAAC,CAAC/C,MAAQA,IAAIC,UAAU,KAAK,SACnC+C,GAAG,CAAC,CAAChD;gBACJ,IAAI;oBACF,MAAM,EAAEE,EAAE,EAAE,GAAGnB,uBAAuBgB,UAAUC,IAAII,IAAI;oBACxD,OAAO,GAAGF,GAAG,EAAE,EAAEA,GAAG,KAAK,CAAC;gBAC5B,EAAE,OAAM;oBACN,OAAO;gBACT;YACF,IAED6C,MAAM,CAACmB,SACPtE,IAAI,CAAC,QACR,2CACA,GACL;;SAEE,EAAER,MAAMgC,OAAO,CAAC,8BAA8B,EAAEhC,MAAMkB,EAAE,CAAC,CAAC,EAAElB,MAAMkB,EAAE,CAAC;AAC9E,EAAE1B,OACA8C,QACGqB,MAAM,CAAC,CAAC/C,MAAQ;oBAAC;oBAAgB;iBAAQ,CAACgE,QAAQ,CAAChE,IAAIC,UAAU,GACjE+C,GAAG,CAAC,CAAChD;gBACJ,OAAO,IAAI,CAACF,kBAAkB,CAACC,UAAUC;YAC3C,IACFJ,IAAI,CAAC,MAAM;;;;;;;;;;;6CAWgC,EAAER,MAAMG,QAAQ,CAAC;;aAEjD,EAAEH,MAAM+E,aAAa,CAAC;;;SAG1B,EAAE/E,MAAM+E,aAAa,CAAC;;UAErB,EAAE/E,MAAM+E,aAAa,CAAC;;;KAG3B,EAAE/E,MAAM+E,aAAa,CAAC;;;;;gBAKX,EAAE/E,MAAM+E,aAAa,CAAC,mBAAmB,EAAE/E,MAAM+E,aAAa,CAAC;;;;iCAI9C,EAAEzC,QAAQqC,IAAI,CAAC,CAAC/D,MAAQ;oBAAC;oBAAmB;iBAAwB,CAACgE,QAAQ,CAAChE,IAAIC,UAAU,KAAK,aAAa,GAAG,iBAAiB,EAAEb,MAAMgC,OAAO,CAAC,YAAY,EAAEgD,KAAKC,SAAS,CAACf,cAAc9C,OAAO,CAAC,cAAc,MAAM;AAC1P,EAAE,AAAC,CAAA;gBACD,MAAM8D,cAAc5C,QAAQqC,IAAI,CAAC,CAAC/D,MAAQA,IAAIC,UAAU,KAAK;gBAC7D,MAAMsE,UAAU7C,QAAQqC,IAAI,CAAC,CAAC/D,MAAQA,IAAIC,UAAU,KAAK;gBACzD,IAAI,CAACqE,eAAe,CAACC,SAAS,OAAO;gBAErC,IAAIC,UAAU;gBACd,IAAIF,aAAa;oBACfE,WAAW,CAAC;;;;;;;;;;;;AAYhB,CAAC;gBACC;gBACA,IAAID,SAAS;oBACXC,WAAW,CAAC;;;;;;;;;;;;AAYhB,CAAC;gBACC;gBACA,OAAOA;YACT,CAAA,IAAK;;;MAGC,EAAEpF,MAAMgC,OAAO,CAAC,WAAW,EAAEhC,MAAMgC,OAAO,CAAC;;;iBAGhC,EAAE,AAAC,CAAA;gBACR,6BAA6B;gBAC7B,MAAMqD,iBAAiB/C,QACpBqB,MAAM,CAAC,CAAC/C,MAAQA,IAAIC,UAAU,KAAK,gBACnC+C,GAAG,CAAC,CAAChD;oBACJ,MAAM0E,eAAe1E,IAAII,IAAI,CAACI,OAAO,CAAC,QAAQ;oBAC9C,IAAIR,IAAIuB,QAAQ,EAAE;wBAChB,OAAO,CAAC,YAAY,EAAEvB,IAAII,IAAI,CAAC,MAAM,EAAEsE,aAAa,aAAa,CAAC;oBACpE,OAAO;wBACL,OAAO,CAAC,YAAY,EAAE1E,IAAII,IAAI,CAAC,MAAM,EAAEsE,aAAa,KAAK,CAAC;oBAC5D;gBACF,GACC9E,IAAI,CAAC;gBACR,OAAO6E;YACT,CAAA,IAAK;;;;;;uBAMQ,EAAErF,MAAMgC,OAAO,CAAC;uBAChB,EACnBM,QAAQqC,IAAI,CAAC,CAAC/D,MAAQ;oBAAC;oBAAmB;iBAAwB,CAACgE,QAAQ,CAAChE,IAAIC,UAAU,KACtF,CAAC;;;;;;wBAMe,EAAEb,MAAMgC,OAAO,CAAC;;;;;;0CAME,EAAEhC,MAAMG,QAAQ,CAAC;;;;;;IAMvD,CAAC,GACG,CAAC;;;;;;wBAMe,EAAEH,MAAMgC,OAAO,CAAC;;;;;;0CAME,EAAEhC,MAAMG,QAAQ,CAAC;;;;;;GAMxD,CAAC,CACD;;;6CAG0C,EAAEQ,SAAS,yCAAyC,EAAEA,SAAS;;;;;;;;;;;;;;;;6DAgB/C,EAAEX,MAAMG,QAAQ,CAAC;;;;;;;;;;;;;;;;;AAiB9E,EAAEmC,QACCqB,MAAM,CAAC,CAAC/C,MAAQA,IAAII,IAAI,KAAK,cAC7B4C,GAAG,CAAC,CAAChD;gBACJ,MAAML,QAAQ,AAAC,CAAA;oBACb,IAAIK,IAAIL,KAAK,CAAC6D,QAAQ,CAAC,OAAO;wBAC5B,IAAI;4BACF,MAAMjB,SAASzD,cAAc0D,GAAG,CAACxC,IAAIL,KAAK,CAACa,OAAO,CAAC,MAAM;4BACzD,OAAO+B,OAAOoC,KAAK,IAAI3E,IAAIL,KAAK;wBAClC,EAAE,OAAM;4BACN,OAAOK,IAAIL,KAAK;wBAClB;oBACF;oBACA,OAAOK,IAAIL,KAAK;gBAClB,CAAA;gBACA,OAAO,CAAC,oBAAoB,EAAEA,MAAM;;kFAE0C,EAAEI,SAAS,CAAC,EAAEC,IAAII,IAAI,CAAC;kBACvF,EAAE,IAAI,CAACS,YAAY,CAACd,UAAUC,KAAKZ,OAAO;sBACtC,CAAC;YACrB,GACCQ,IAAI,CAAC,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;MA2BV,CAAC,CAACgF,IAAI;YACNC,YAAY,EAAE;YACdtB;QACF;IACF;AACF"}
481
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/template/implementations/view_form.template.ts"],"sourcesContent":["import inflection from \"inflection\";\nimport { unique } from \"radashi\";\nimport { z } from \"zod\";\nimport { EntityManager, type EntityNamesRecord } from \"../../entity/entity-manager\";\nimport type { RenderingNode, TemplateKey, TemplateOptions } from \"../../types/types\";\nimport { getEnumInfoFromColName, getRelationPropFromColName } from \"../helpers\";\nimport type { RenderedTemplate } from \"../template\";\nimport { Template } from \"../template\";\n\nexport class Template__view_form extends Template {\n  constructor() {\n    super(\"view_form\");\n  }\n\n  getTargetAndPath(names: EntityNamesRecord) {\n    return {\n      target: \"web/src/routes/admin\",\n      path: `${names.fsPlural}/form.tsx`,\n    };\n  }\n\n  override getRequiredDictKeys(): string[] | null {\n    return [\"entity.create\", \"entity.edit\", \"common.backToList\", \"form.createdAt\", \"common.save\"];\n  }\n\n  wrapFC(body: string, label?: string): string {\n    return [\n      `<div className=\"space-y-2\">${label ? `\\n  <Label>${label}</Label>` : \"\"}`,\n      `  ${body}`,\n      `</div>`,\n    ].join(\"\\n\");\n  }\n  wrapFG(body: string, label?: string): string {\n    return this.wrapFC(body, label);\n  }\n\n  renderColumnImport(entityId: string, col: RenderingNode) {\n    if (col.renderType === \"enums\") {\n      const { id, targetEntityNames } = getEnumInfoFromColName(entityId, col.name);\n      const componentId = `${id}Select`;\n      return `import { ${componentId} } from \"@/components/${targetEntityNames.fs}/${componentId}\";`;\n    } else if (col.renderType === \"number-fk_id\") {\n      try {\n        const relProp = getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n        const targetNames = EntityManager.getNamesFromId(relProp.with);\n        const componentId = `${relProp.with}IdAsyncSelect`;\n        return `import { ${componentId} } from \"@/components/${targetNames.fs}/${componentId}\";`;\n      } catch {\n        return \"\";\n      }\n    } else {\n      throw new Error(`렌더 불가능한 임포트 ${col.name} ${col.renderType}`);\n    }\n  }\n\n  renderColumn(entityId: string, col: RenderingNode, names: EntityNamesRecord): string {\n    const regExpr = `{...register(\"${col.name}\")}`;\n    const placeholder = `{SD(\"entity.${entityId}.${col.name}\")}`;\n\n    switch (col.renderType) {\n      case \"string-plain\":\n        if (col.zodType instanceof z.ZodString && (col.zodType.maxLength ?? 0) <= 256) {\n          return `<Input className=\"h-8 text-xs bg-white\" placeholder=${placeholder} ${regExpr} />`;\n        } else {\n          return `<Textarea className=\"text-xs bg-white\" rows={4} placeholder=${placeholder} ${regExpr} />`;\n        }\n      case \"datetime\":\n        return `<DateInput\n                    className=\"h-8 text-xs bg-white\"\n                    ${regExpr}\n                  />`;\n      case \"number-id\":\n        return `<input type=\"hidden\" ${regExpr} />`;\n      case \"number-plain\":\n        return `<Input type=\"number\" className=\"h-8 text-xs bg-white\" placeholder=${placeholder} ${regExpr} />`;\n      case \"boolean\":\n        return `<Switch ${regExpr} />`;\n      case \"json-sonamufile\":\n        return `<FileInput\n                    uploadMode=\"lazy\"\n                    viewMode=\"image\"\n                    previewSize=\"md\"\n                    ${regExpr}\n                  />`;\n      case \"json-sonamufile-array\":\n        return `<FileInput\n                    multiple={true}\n                    uploadMode=\"lazy\"\n                    viewMode=\"image\"\n                    previewSize=\"md\"\n                    maxFiles={10}\n                    ${regExpr}\n                  />`;\n      case \"enums\":\n        try {\n          let enumId: string;\n          if (col.name === \"orderBy\") {\n            enumId = `${names.capital}${inflection.camelize(col.name)}Select`;\n          } else {\n            const { id } = getEnumInfoFromColName(entityId, col.name);\n            enumId = `${id}Select`;\n          }\n          return `<${enumId} ${regExpr} ${col.optional || col.nullable ? \"clearable\" : \"\"} />`;\n        } catch {\n          return `<Input className=\"h-8 text-xs bg-white\" ${regExpr} />`;\n        }\n      case \"number-fk_id\":\n        try {\n          const relProp = getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n          const fkId = `${relProp.with}IdAsyncSelect`;\n          return `<${fkId} subset=\"A\" ${regExpr} ${\n            col.optional || col.nullable ? \"clearable\" : \"\"\n          } className=\"h-8 text-xs\" />`;\n        } catch {\n          return `<Input type=\"number\" className=\"h-8 text-xs bg-white\" placeholder=${placeholder} ${regExpr} />`;\n        }\n      case \"array\":\n      case \"object\":\n        return `<Input className=\"h-8 text-xs bg-white\" placeholder=\"${col.name}\" ${regExpr} />`;\n      default:\n        return `<Input className=\"h-8 text-xs bg-white\" ${regExpr} />`;\n    }\n  }\n\n  resolveDefaultValue(columns: RenderingNode[]): object {\n    return columns.reduce(\n      (result, col) => {\n        if (col.optional) {\n          return result;\n        }\n\n        let value: unknown;\n        if (col.nullable === true) {\n          value = null;\n        } else if (col.zodType instanceof z.ZodNumber) {\n          value = 0;\n        } else if (col.zodType instanceof z.ZodEnum) {\n          value = Object.keys(col.zodType.enum)[0];\n        } else if (col.zodType instanceof z.ZodBoolean) {\n          value = false;\n        } else if (col.zodType instanceof z.core.$ZodString) {\n          // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함\n          // FIXME: email이나 url 타입 등에 대한 처리가 필요함\n          if (col.renderType === \"string-datetime\") {\n            value = \"now()\";\n          } else {\n            value = \"\";\n          }\n        } else if (col.zodType instanceof z.ZodArray) {\n          value = [];\n        } else if (col.zodType instanceof z.ZodObject) {\n          value = {};\n        }\n\n        result[col.name] = value;\n        return result;\n      },\n      {} as { [key: string]: unknown },\n    );\n  }\n\n  async render({ entityId }: TemplateOptions[\"view_form\"]) {\n    const entity = EntityManager.get(entityId);\n    const names = EntityManager.getNamesFromId(entityId);\n\n    // SaveParams 타입을 로드하여 saveParamsNode 생성\n    const { loadTypes } = await import(\"../../syncer/module-loader\");\n    const loadedTypes = await loadTypes();\n    const SaveParamsZodType = loadedTypes[`${entityId}SaveParams`];\n\n    if (!SaveParamsZodType) {\n      throw new Error(`SaveParams for ${entityId} not found. Did you run 'sonamu sync'?`);\n    }\n\n    // Zod 타입을 RenderingNode로 변환\n    const { zodTypeToRenderingNode } = await import(\"../zod-converter\");\n    const saveParamsNode = zodTypeToRenderingNode(SaveParamsZodType);\n\n    const columns = ((saveParamsNode?.children ?? []) as RenderingNode[])\n      .filter((col) => col.name !== \"id\")\n      .map((col) => {\n        const propCandidate = entity.props.find((prop) => prop.name === col.name);\n        col.label = propCandidate?.desc ?? col.label;\n        return col;\n      });\n\n    const defaultValue = this.resolveDefaultValue(columns);\n\n    // 프리 템플릿\n    const preTemplates: RenderedTemplate[\"preTemplates\"] = (columns as RenderingNode[])\n      .filter((col) => {\n        if (col.name === \"id\") {\n          return false;\n        } else if (col.name.endsWith(\"_id\") || col.renderType === \"number-id\") {\n          try {\n            getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n            return true;\n          } catch {\n            return false;\n          }\n        } else if (col.renderType === \"enums\") {\n          try {\n            getEnumInfoFromColName(entityId, col.name);\n            return true;\n          } catch {\n            return false;\n          }\n        }\n        return false;\n      })\n      .map((col) => {\n        let key: TemplateKey;\n        let targetMdId = entityId;\n        let enumId: string | undefined;\n        if (col.renderType === \"enums\") {\n          key = \"view_enums_select\";\n          const { targetEntityNames: targetMDNames, id } = getEnumInfoFromColName(\n            entityId,\n            col.name,\n          );\n          targetMdId = targetMDNames.capital;\n          enumId = id;\n        } else {\n          key = \"view_id_async_select\";\n          const relProp = getRelationPropFromColName(entityId, col.name.replace(\"_id\", \"\"));\n          targetMdId = relProp.with;\n        }\n\n        return {\n          key: key as TemplateKey,\n          options: {\n            entityId: targetMdId,\n            node: col,\n            enumId,\n          },\n        };\n      })\n      .filter((preTemplate) => {\n        if (preTemplate.key === \"view_id_async_select\") {\n          try {\n            EntityManager.get(preTemplate.options.entityId);\n            return true;\n          } catch {\n            return false;\n          }\n        }\n        return true;\n      });\n\n    return {\n      ...this.getTargetAndPath(names),\n      body: `\nimport {\n  Button,\n  Card,\n  CardContent,\n  CardHeader,\n  CardTitle,\n  Input,${columns.some((col) => col.renderType === \"string-plain\" && col.zodType instanceof z.ZodString && (col.zodType.maxLength ?? 0) > 256) ? \"\\n  Textarea,\" : \"\"}${columns.some((col) => col.renderType === \"enums\") ? \"\\n  Select,\\n  SelectContent,\\n  SelectItem,\\n  SelectTrigger,\\n  SelectValue,\" : \"\"}${columns.some((col) => col.renderType === \"boolean\") ? \"\\n  Switch,\" : \"\"}${columns.some((col) => [\"json-sonamufile\", \"json-sonamufile-array\"].includes(col.renderType)) ? \"\\n  FileInput,\" : \"\"}${columns.some((col) => [\"string-datetime\", \"string-date\", \"datetime\"].includes(col.renderType)) ? \"\\n  DateInput,\" : \"\"}\n} from \"@sonamu-kit/react-components/components\";\nimport { useTypeForm } from \"@sonamu-kit/react-components/lib\";\nimport { useQueryClient } from \"@tanstack/react-query\";\nimport { createFileRoute, useRouter } from \"@tanstack/react-router\";\nimport { useEffect } from \"react\";\nimport { z } from \"zod\";\nimport { ${names.capital}Service } from \"@/services/services.generated\";\nimport type { ${names.capital}SubsetA } from \"@/services/sonamu.generated\";${\n        columns.filter((col) => col.renderType === \"enums\").length > 0\n          ? \"\\nimport { \" +\n            unique(\n              columns\n                .filter((col) => col.renderType === \"enums\")\n                .map((col) => {\n                  try {\n                    const { id } = getEnumInfoFromColName(entityId, col.name);\n                    return `${id}, ${id}Label`;\n                  } catch {\n                    return \"\";\n                  }\n                }),\n            )\n              .filter(Boolean)\n              .join(\", \") +\n            ' } from \"@/services/sonamu.generated\";'\n          : \"\"\n      }\nimport { defaultCatch } from \"@/services/sonamu.shared\";\nimport { ${names.capital}SaveParams } from \"@/services/${names.fs}/${names.fs}.types\";\n${unique(\n  columns\n    .filter((col) => [\"number-fk_id\", \"enums\"].includes(col.renderType))\n    .map((col) => {\n      return this.renderColumnImport(entityId, col);\n    }),\n).join(\"\\n\")}\nimport { SD } from \"@/i18n/sd.generated\";\n\nimport ArrowLeftIcon from \"~icons/lucide/arrow-left\";\nimport SaveIcon from \"~icons/lucide/save\";\nimport FormIcon from \"~icons/mdi/form-select\";\n\nconst formSearchSchema = z.object({\n  id: z.number().optional(),\n});\n\nexport const Route = createFileRoute(\"/admin/${names.fsPlural}/form\")({\n  validateSearch: formSearchSchema,\n  component: ${names.capitalPlural}FormPage,\n});\n\nfunction ${names.capitalPlural}FormPage() {\n  const { id } = Route.useSearch();\n  return <${names.capitalPlural}Form id={id} />;\n}\n\ntype ${names.capitalPlural}FormProps = {\n  id?: number;\n  mode?: \"page\" | \"modal\";\n};\n\nexport function ${names.capitalPlural}Form({ id, mode }: ${names.capitalPlural}FormProps) {\n  const router = useRouter();\n  const queryClient = useQueryClient();\n\n  const { form, setForm, register${columns.some((col) => [\"json-sonamufile\", \"json-sonamufile-array\"].includes(col.renderType)) ? \", submit\" : \"\"} } = useTypeForm(${names.capital}SaveParams, ${JSON.stringify(defaultValue).replace(/\"now\\(\\)\"/g, '\"\"')});\n${(() => {\n  const hasDatetime = columns.some((col) => col.renderType === \"string-datetime\");\n  const hasDate = columns.some((col) => col.renderType === \"string-date\");\n  if (!hasDatetime && !hasDate) return \"\";\n\n  let helpers = \"\\n\";\n  if (hasDatetime) {\n    helpers += `  // datetime-local 형식으로 변환 (YYYY-MM-DDTHH:MM)\n  const toDatetimeLocalString = (date: Date | string | null | undefined): string => {\n    if (!date) return \"\";\n    const d = typeof date === \"string\" ? new Date(date) : date;\n    return d.toISOString().slice(0, 16);\n  };\n\n  // datetime-local 문자열을 Date로 변환\n  const fromDatetimeLocalString = (value: string): Date | null => {\n    if (!value) return null;\n    return new Date(value);\n  };\n`;\n  }\n  if (hasDate) {\n    helpers += `  // date 형식으로 변환 (YYYY-MM-DD)\n  const toDateString = (date: Date | string | null | undefined): string => {\n    if (!date) return \"\";\n    const d = typeof date === \"string\" ? new Date(date) : date;\n    return d.toISOString().split(\"T\")[0];\n  };\n\n  // date 문자열을 Date로 변환\n  const fromDateString = (value: string): Date | null => {\n    if (!value) return null;\n    return new Date(value);\n  };\n`;\n  }\n  return helpers;\n})()}\n  useEffect(() => {\n    if (id) {\n      ${names.capital}Service.get${names.capital}(\"A\", id).then((row) => {\n        setForm((prevForm) => ({\n          ...prevForm,\n          ...row,${(() => {\n            // relation 필드들을 찾아서 변환 코드 생성\n            const relationFields = columns\n              .filter((col) => col.renderType === \"number-fk_id\")\n              .map((col) => {\n                const relationName = col.name.replace(/_id$/, \"\");\n                if (col.nullable) {\n                  return `\\n          ${col.name}: row.${relationName}?.id ?? null,`;\n                } else {\n                  return `\\n          ${col.name}: row.${relationName}?.id,`;\n                }\n              })\n              .join(\"\");\n            return relationFields;\n          })()}\n        }));\n      });\n    }\n  }, [id, setForm]);\n\n  const saveMutation = ${names.capital}Service.useSaveMutation();\n  const handleSubmit = ${\n    columns.some((col) => [\"json-sonamufile\", \"json-sonamufile-array\"].includes(col.renderType))\n      ? `submit(async (form) => {\n    saveMutation.mutate(\n      { spa: [form] },\n      {\n        onSuccess: () => {\n          queryClient.invalidateQueries({\n            queryKey: [\"${names.capital}\"],\n          });\n\n          if (mode === \"modal\") {\n            // modal mode\n          } else {\n            router.navigate({ to: \"/admin/${names.fsPlural}\" });\n          }\n        },\n        onError: defaultCatch,\n      },\n    );\n  })`\n      : `() => {\n    saveMutation.mutate(\n      { spa: [form] },\n      {\n        onSuccess: () => {\n          queryClient.invalidateQueries({\n            queryKey: [\"${names.capital}\"],\n          });\n\n          if (mode === \"modal\") {\n            // modal mode\n          } else {\n            router.navigate({ to: \"/admin/${names.fsPlural}\" });\n          }\n        },\n        onError: defaultCatch,\n      },\n    );\n  }`\n  };\n\n  const PAGE = {\n    title: id ? SD(\"entity.edit\")(SD(\"entity.${entityId}\"), id) : SD(\"entity.create\")(SD(\"entity.${entityId}\")),\n  };\n\n  return (\n    <div className=\"flex-1 overflow-auto\">\n      <div className=\"max-w-[1800px] mx-auto p-8\">\n        <div className=\"space-y-6 mb-8\">\n          {/* Header */}\n          <div className=\"flex items-center justify-between\">\n            <div className=\"flex items-center gap-2\">\n              <FormIcon className=\"h-5 w-5\" />\n              <span className=\"text-lg font-semibold h-5\">{PAGE.title}</span>\n            </div>\n            {mode !== \"modal\" && (\n              <Button\n                variant=\"outline\"\n                onClick={() => router.navigate({ to: \"/admin/${names.fsPlural}\" })}\n                icon={<ArrowLeftIcon />}\n              >\n                {SD(\"common.backToList\")}\n              </Button>\n            )}\n          </div>\n\n          {/* Form Card */}\n          <Card className=\"border-border/40 bg-gray-50 shadow-sm\">\n            <CardHeader className=\"px-4 border-b border-gray-200 flex items-center\">\n              <CardTitle className=\"text-sm font-medium leading-none m-0\">\n                {PAGE.title}\n              </CardTitle>\n            </CardHeader>\n            <CardContent className=\"p-6\">\n              <div className=\"space-y-6\">\n${columns\n  .filter((col) => col.name !== \"created_at\")\n  .map((col) => {\n    const label = (() => {\n      if (col.label.endsWith(\"Id\")) {\n        try {\n          const entity = EntityManager.get(col.label.replace(\"Id\", \"\"));\n          return entity.title ?? col.label;\n        } catch {\n          return col.label;\n        }\n      }\n      return col.label;\n    })();\n    return `                {/* ${label} */}\n                <div className=\"space-y-2\">\n                  <label className=\"block text-xs mb-1 text-gray-600\">{SD(\"entity.${entityId}.${col.name}\")}</label>\n                  ${this.renderColumn(entityId, col, names)}\n                </div>`;\n  })\n  .join(\"\\n\\n\")}\n\n                {/* Save Button */}\n                <div className=\"flex items-center justify-between pt-4\">\n                  {form.id && form.created_at && (\n                    <div className=\"flex items-center\">\n                      <label className=\"mr-2 text-xs text-gray-600\">{SD(\"form.createdAt\")}:</label>\n                      <span className=\"text-xs text-gray-600\">\n                        {String(form.created_at)}\n                      </span>\n                    </div>\n                  )}\n                  <Button\n                    onClick={handleSubmit}\n                    icon={<SaveIcon />}\n                  >\n                    {SD(\"common.save\")}\n                  </Button>\n                </div>\n              </div>\n            </CardContent>\n          </Card>\n        </div>\n      </div>\n    </div>\n  );\n}\n      `.trim(),\n      importKeys: [],\n      preTemplates,\n    };\n  }\n}\n"],"names":["inflection","unique","z","EntityManager","getEnumInfoFromColName","getRelationPropFromColName","Template","Template__view_form","getTargetAndPath","names","target","path","fsPlural","getRequiredDictKeys","wrapFC","body","label","join","wrapFG","renderColumnImport","entityId","col","renderType","id","targetEntityNames","name","componentId","fs","relProp","replace","targetNames","getNamesFromId","with","Error","renderColumn","regExpr","placeholder","zodType","ZodString","maxLength","enumId","capital","camelize","optional","nullable","fkId","resolveDefaultValue","columns","reduce","result","value","ZodNumber","ZodEnum","Object","keys","enum","ZodBoolean","core","$ZodString","ZodArray","ZodObject","render","entity","get","loadTypes","loadedTypes","SaveParamsZodType","zodTypeToRenderingNode","saveParamsNode","children","filter","map","propCandidate","props","find","prop","desc","defaultValue","preTemplates","endsWith","key","targetMdId","targetMDNames","options","node","preTemplate","some","includes","length","Boolean","capitalPlural","JSON","stringify","hasDatetime","hasDate","helpers","relationFields","relationName","title","trim","importKeys"],"mappings":"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"}
@@ -527,7 +527,9 @@ export function zodTypeToTsTypeDef(zt) {
527
527
  */ function resolveRenderType(key, zodType) {
528
528
  if (zodType instanceof z.ZodDate) {
529
529
  return "datetime";
530
- } else if (zodType instanceof z.ZodString) {
530
+ } else if (zodType instanceof z.core.$ZodString) {
531
+ // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함
532
+ // FIXME: email이나 url 타입 등에 대한 처리가 필요함
531
533
  if (zodType.description === "SQLDateTimeString") {
532
534
  return "string-datetime";
533
535
  } else if (key.endsWith("date")) {
@@ -562,4 +564,4 @@ export function zodTypeToTsTypeDef(zt) {
562
564
  }
563
565
  }
564
566
 
565
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/template/zod-converter.ts"],"sourcesContent":["/**\n * zod-converter 구성\n * 1. 유틸리티\n *  - getZodTypeById\n *\n * 2. Zod 타입 변환 (EntityProp -> ZodType)\n *  - propToZodType\n *\n * 3. EntityProp/Node -> Zod 코드 문자열\n *  - propToZodTypeDef\n *  - propNodeToZodTypeDef\n *\n * 4. Zod 타입 인스턴스를 해당하는 Zod 코드 문자열로 변환 (ZodType -> ZodCode)\n *  - zodTypeToZodCode\n *\n * 5. Zod 타입을 UI 렌더링에 사용할 수 있는 RenderingNode로 변환 (ZodType -> RenderingNode)\n *  - zodTypeToRenderingNode\n *  - resolveRenderType\n */\n\nimport inflection from \"inflection\";\nimport path from \"path\";\nimport { z } from \"zod\";\nimport type { $ZodLooseShape } from \"zod/v4/core\";\nimport { Sonamu } from \"../api/sonamu\";\nimport { EntityManager } from \"../entity/entity-manager\";\nimport {\n  BUILT_IN_TYPE_IDS,\n  type EntityProp,\n  type EntityPropNode,\n  isBelongsToOneRelationProp,\n  isBigIntegerArrayProp,\n  isBigIntegerSingleProp,\n  isBooleanArrayProp,\n  isBooleanSingleProp,\n  isDateArrayProp,\n  isDateSingleProp,\n  isEnumArrayProp,\n  isEnumSingleProp,\n  isIntegerArrayProp,\n  isIntegerSingleProp,\n  isJsonProp,\n  isNumberArrayProp,\n  isNumberSingleProp,\n  isNumericArrayProp,\n  isNumericSingleProp,\n  isOneToOneRelationProp,\n  isRelationProp,\n  isStringArrayProp,\n  isStringSingleProp,\n  isTsVectorProp,\n  isUuidArrayProp,\n  isUuidSingleProp,\n  isVectorArrayProp,\n  isVectorSingleProp,\n  isVirtualProp,\n  type RenderingNode,\n  SonamuFileArraySchema,\n  SonamuFileSchema,\n} from \"../types/types\";\nimport { createImportUrl } from \"../utils/esm-utils\";\nimport { runtimePath } from \"../utils/path-utils\";\n\n// <any>를 자제하고, Zod에서 제약하는 기본적인 Generic Type Parameter를 사용함.\ntype AnyZodRecord = z.ZodRecord<z.ZodString | z.ZodNumber | z.ZodSymbol, z.ZodType>;\ntype AnyZodObject = z.ZodObject<$ZodLooseShape>;\ntype AnyZodNullable = z.ZodNullable<z.ZodType>;\ntype AnyZodDefault = z.ZodDefault<z.ZodType>;\ntype AnyZodUnion = z.ZodUnion<z.ZodType[]>;\ntype AnyZodArray = z.ZodArray<z.ZodType>;\ntype AnyZodOptional = z.ZodOptional<z.ZodType>;\ntype AnyZodTemplateLiteral = z.ZodTemplateLiteral<string>;\n\n/**\n * 내장 타입 정의 (Zod 스키마 + UI 렌더링 타입)\n */\nexport const BUILT_IN_TYPES = {\n  SonamuFile: {\n    schema: SonamuFileSchema,\n    renderType: \"json-sonamufile\",\n    schemaName: \"SonamuFileSchema\",\n  },\n  \"SonamuFile[]\": {\n    schema: SonamuFileArraySchema,\n    renderType: \"json-sonamufile-array\",\n    schemaName: \"SonamuFileArraySchema\",\n  },\n} as const;\n\n/**\n * Zod 타입 ID로부터 동적으로 Zod 스키마를 로드합니다.\n * 내장 타입(BUILT_IN_TYPE_IDS)은 바로 반환하고,\n * 그 외는 dist 디렉토리에서 ESM으로 import하여 가져옵니다.\n */\nexport async function getZodTypeById(zodTypeId: string): Promise<z.ZodTypeAny> {\n  // 내장 타입 처리\n  if ((BUILT_IN_TYPE_IDS as readonly string[]).includes(zodTypeId)) {\n    const builtInType = BUILT_IN_TYPES[zodTypeId as keyof typeof BUILT_IN_TYPES];\n    if (!builtInType) {\n      throw new Error(`내장 타입 ${zodTypeId}의 스키마가 정의되지 않았습니다`);\n    }\n    return builtInType.schema.describe(zodTypeId);\n  }\n\n  // 프로젝트에서 정의한 타입 동적 로드\n  const modulePath = EntityManager.getModulePath(zodTypeId);\n  const moduleAbsPath = path.join(\n    Sonamu.apiRootPath,\n    runtimePath(`dist/application/${modulePath}.js`),\n  );\n  const importUrl = createImportUrl(moduleAbsPath);\n  const imported = await import(importUrl);\n\n  if (!imported[zodTypeId]) {\n    throw new Error(`존재하지 않는 zodTypeId ${zodTypeId}`);\n  }\n  return imported[zodTypeId].describe(zodTypeId);\n}\n\n/**\n * EntityProp을 Zod 타입으로 변환합니다.\n * 각 prop의 타입에 따라 적절한 Zod validator를 생성합니다.\n */\nexport async function propToZodType(prop: EntityProp): Promise<z.ZodTypeAny> {\n  let zodType: z.ZodTypeAny = z.unknown();\n  if (isIntegerSingleProp(prop)) {\n    zodType = z.number().int();\n  } else if (isIntegerArrayProp(prop)) {\n    zodType = z.number().int().array();\n  } else if (isBigIntegerSingleProp(prop)) {\n    zodType = z.bigint();\n  } else if (isBigIntegerArrayProp(prop)) {\n    zodType = z.bigint().array();\n  } else if (isEnumSingleProp(prop)) {\n    zodType = await getZodTypeById(prop.id);\n  } else if (isEnumArrayProp(prop)) {\n    zodType = (await getZodTypeById(prop.id)).array();\n  } else if (isStringSingleProp(prop)) {\n    if (prop.length) {\n      zodType = z.string().max(prop.length);\n    } else {\n      zodType = z.string();\n    }\n  } else if (isStringArrayProp(prop)) {\n    if (prop.length) {\n      zodType = z.string().max(prop.length).array();\n    } else {\n      zodType = z.string().array();\n    }\n  } else if (isNumberSingleProp(prop)) {\n    zodType = z.number();\n  } else if (isNumberArrayProp(prop)) {\n    zodType = z.number().array();\n  } else if (isNumericSingleProp(prop)) {\n    zodType = z.string();\n  } else if (isNumericArrayProp(prop)) {\n    zodType = z.string().array();\n  } else if (isBooleanSingleProp(prop)) {\n    zodType = z.boolean();\n  } else if (isBooleanArrayProp(prop)) {\n    zodType = z.boolean().array();\n  } else if (isDateSingleProp(prop)) {\n    zodType = z.date();\n  } else if (isDateArrayProp(prop)) {\n    zodType = z.date().array();\n  } else if (isUuidSingleProp(prop)) {\n    zodType = z.uuid();\n  } else if (isUuidArrayProp(prop)) {\n    zodType = z.uuid().array();\n  } else if (isJsonProp(prop)) {\n    zodType = await getZodTypeById(prop.id);\n  } else if (isVectorSingleProp(prop)) {\n    zodType = z.array(z.number());\n  } else if (isVectorArrayProp(prop)) {\n    zodType = z.array(z.array(z.number()));\n  } else if (isVirtualProp(prop)) {\n    zodType = await getZodTypeById(prop.id);\n  } else if (isRelationProp(prop)) {\n    if (isBelongsToOneRelationProp(prop) || (isOneToOneRelationProp(prop) && prop.hasJoinColumn)) {\n      zodType = z.number().int();\n    }\n  } else {\n    throw new Error(`prop을 zodType으로 변환하는데 실패 ${prop}}`);\n  }\n\n  if ((prop as { unsigned?: boolean }).unsigned) {\n    zodType = (zodType as z.ZodNumber).nonnegative();\n  }\n  if (prop.nullable) {\n    zodType = zodType.nullable();\n  }\n\n  return zodType;\n}\n\n/**\n * EntityProp을 Zod 타입 정의 코드 문자열로 변환합니다.\n */\nexport function propToZodTypeDef(prop: EntityProp, injectImportKeys: string[]): string {\n  let stmt: string;\n  if (isIntegerSingleProp(prop)) {\n    stmt = `${prop.name}: z.int()`;\n  } else if (isIntegerArrayProp(prop)) {\n    stmt = `${prop.name}: z.int().array()`;\n  } else if (isBigIntegerSingleProp(prop)) {\n    stmt = `${prop.name}: z.bigint()`;\n  } else if (isBigIntegerArrayProp(prop)) {\n    stmt = `${prop.name}: z.bigint().array()`;\n  } else if (isEnumSingleProp(prop)) {\n    stmt = `${prop.name}: ${prop.id}`;\n    injectImportKeys.push(prop.id);\n  } else if (isEnumArrayProp(prop)) {\n    stmt = `${prop.name}: ${prop.id}.array()`;\n    injectImportKeys.push(prop.id);\n  } else if (isStringSingleProp(prop)) {\n    if (prop.length) {\n      stmt = `${prop.name}: z.string().max(${prop.length})`;\n    } else {\n      stmt = `${prop.name}: z.string()`;\n    }\n  } else if (isStringArrayProp(prop)) {\n    if (prop.length) {\n      stmt = `${prop.name}: z.string().max(${prop.length}).array()`;\n    } else {\n      stmt = `${prop.name}: z.string().array()`;\n    }\n  } else if (isNumberSingleProp(prop)) {\n    stmt = `${prop.name}: z.number()`;\n  } else if (isNumberArrayProp(prop)) {\n    stmt = `${prop.name}: z.number().array()`;\n  } else if (isNumericSingleProp(prop)) {\n    stmt = `${prop.name}: z.string()`;\n  } else if (isNumericArrayProp(prop)) {\n    stmt = `${prop.name}: z.string().array()`;\n  } else if (isDateSingleProp(prop)) {\n    stmt = `${prop.name}: z.date()`;\n  } else if (isDateArrayProp(prop)) {\n    stmt = `${prop.name}: z.date().array()`;\n  } else if (isBooleanSingleProp(prop)) {\n    stmt = `${prop.name}: z.boolean()`;\n  } else if (isBooleanArrayProp(prop)) {\n    stmt = `${prop.name}: z.boolean().array()`;\n  } else if (isUuidSingleProp(prop)) {\n    stmt = `${prop.name}: z.uuid()`;\n  } else if (isUuidArrayProp(prop)) {\n    stmt = `${prop.name}: z.uuid().array()`;\n  } else if (isJsonProp(prop)) {\n    // 내장 타입인 경우 스키마 이름으로 변환\n    if ((BUILT_IN_TYPE_IDS as readonly string[]).includes(prop.id)) {\n      const schemaName = prop.id === \"SonamuFile\" ? \"SonamuFileSchema\" : \"SonamuFileArraySchema\";\n      stmt = `${prop.name}: ${schemaName}`;\n      injectImportKeys.push(schemaName);\n    } else {\n      stmt = `${prop.name}: ${prop.id}`;\n      injectImportKeys.push(prop.id);\n    }\n  } else if (isVectorSingleProp(prop)) {\n    stmt = `${prop.name}: z.array(z.number())`;\n  } else if (isVectorArrayProp(prop)) {\n    stmt = `${prop.name}: z.array(z.array(z.number()))`;\n  } else if (isTsVectorProp(prop)) {\n    stmt = `${prop.name}: z.string()`;\n  } else if (isVirtualProp(prop)) {\n    stmt = `${prop.name}: ${prop.id}`;\n    injectImportKeys.push(prop.id);\n  } else if (isRelationProp(prop)) {\n    if (isBelongsToOneRelationProp(prop) || (isOneToOneRelationProp(prop) && prop.hasJoinColumn)) {\n      stmt = `${prop.name}_id: z.int()`;\n    } else {\n      // 그외 relation 케이스 제외\n      return `// ${prop.name}: ${prop.relationType} ${prop.with}`;\n    }\n  } else {\n    return \"// unable to resolve\";\n  }\n\n  if ((prop as { unsigned?: boolean }).unsigned) {\n    stmt += \".nonnegative()\";\n  }\n  if (prop.nullable) {\n    stmt += \".nullable()\";\n  }\n\n  return `${stmt},`;\n}\n\n/**\n * EntityPropNode를 Zod 타입 정의 코드 문자열로 변환합니다.\n * plain, array, object 노드 타입을 재귀적으로 처리하여 중첩 구조를 지원합니다.\n */\nexport function propNodeToZodTypeDef(propNode: EntityPropNode, injectImportKeys: string[]): string {\n  if (propNode.nodeType === \"plain\") {\n    return propToZodTypeDef(propNode.prop, injectImportKeys);\n  } else if (propNode.nodeType === \"array\") {\n    return [\n      propNode.prop ? `${propNode.prop.name}: ` : \"\",\n      \"z.array(z.object({\",\n      propNode.children\n        .map((childPropNode) => propNodeToZodTypeDef(childPropNode, injectImportKeys))\n        .join(\"\\n\"),\n      \"\",\n      \"})),\",\n    ].join(\"\\n\");\n  } else if (propNode.nodeType === \"object\") {\n    return [\n      propNode.prop ? `${propNode.prop.name}: ` : \"\",\n      \"z.object({\",\n      propNode.children\n        .map((childPropNode) => propNodeToZodTypeDef(childPropNode, injectImportKeys))\n        .join(\"\\n\"),\n      \"\",\n      `})${propNode.prop?.nullable ? \".nullable()\" : \"\"},`,\n    ].join(\"\\n\");\n  } else {\n    throw Error;\n  }\n}\n\nexport function zodTypeToTsTypeDef(zt: z.ZodType): string {\n  switch (zt.def.type) {\n    case \"string\":\n    case \"number\":\n    case \"boolean\":\n    case \"bigint\":\n    case \"date\":\n    case \"null\":\n    case \"undefined\":\n    case \"any\":\n    case \"unknown\":\n    case \"never\":\n      return zt.def.type;\n    case \"nullable\":\n      return `${zodTypeToTsTypeDef((zt as AnyZodNullable).def.innerType)} | null`;\n    case \"default\":\n      return zodTypeToTsTypeDef((zt as AnyZodDefault).def.innerType);\n    case \"record\": {\n      const recordType = zt as AnyZodRecord;\n      return `{ [ key: ${zodTypeToTsTypeDef(recordType.def.keyType)} ]: ${zodTypeToTsTypeDef(recordType.def.valueType)}}`;\n    }\n    case \"literal\":\n      return Array.from((zt as z.ZodLiteral).values)\n        .map((value) => {\n          if (typeof value === \"string\") {\n            return `\"${value}\"`;\n          }\n\n          if (value === null) {\n            return `null`;\n          }\n\n          if (value === undefined) {\n            return `undefined`;\n          }\n\n          return `${value}`;\n        })\n        .join(\" | \");\n    case \"union\":\n      return `${(zt as AnyZodUnion).options\n        .map((option) => zodTypeToTsTypeDef(option))\n        .join(\" | \")}`;\n    case \"enum\":\n      return `${(zt as z.ZodEnum).options.map((val) => `\"${val}\"`).join(\" | \")}`;\n    case \"array\":\n      return `${zodTypeToTsTypeDef((zt as AnyZodArray).element)}[]`;\n    case \"object\": {\n      const shape = (zt as AnyZodObject).shape;\n      return [\n        \"{\",\n        ...Object.keys(shape).map((key) => {\n          if (shape[key].def.type === \"optional\") {\n            return `${key}?: ${zodTypeToTsTypeDef(shape[key].def.innerType)},`;\n          } else {\n            return `${key}: ${zodTypeToTsTypeDef(shape[key])},`;\n          }\n        }),\n        \"}\",\n      ].join(\"\\n\");\n    }\n    case \"optional\":\n      return `${zodTypeToTsTypeDef((zt as AnyZodOptional).def.innerType)} | undefined`;\n    case \"template_literal\": {\n      const def = (zt as AnyZodTemplateLiteral).def;\n\n      // 빈 template literal은 string으로 폴백\n      if (!def.parts || def.parts.length === 0) {\n        return \"string\";\n      }\n\n      // 각 part를 TypeScript 타입 문자열로 변환\n      const parts = def.parts.map((part: unknown) => {\n        // 리터럴 값 (string, number, boolean, null, undefined)\n        if (typeof part === \"string\") {\n          return `${part}`;\n        }\n\n        // ZodType - 재귀적으로 변환\n        if (part && typeof part === \"object\" && (part as z.ZodType)._zod) {\n          const innerType = zodTypeToTsTypeDef(part as z.ZodType);\n          return `$\\{${innerType}}`;\n        }\n\n        // 폴백\n        return `\\${string}`;\n      });\n\n      return `\\`${parts.join(\"\")}\\``;\n    }\n    case \"file\":\n      return \"File\";\n    default:\n      throw new Error(`처리되지 않은 ZodType ${zt.def.type}`);\n  }\n}\n\n/**\n * Zod 타입 인스턴스를 해당하는 Zod 코드 문자열로 변환합니다.\n */\nexport function zodTypeToZodCode(zt: z.ZodType): string {\n  switch (zt.def.type) {\n    case \"string\":\n      return \"z.string()\";\n    case \"number\":\n      return \"z.number()\";\n    case \"bigint\":\n      return \"z.bigint()\";\n    case \"boolean\":\n      return \"z.boolean()\";\n    case \"date\":\n      return \"z.date()\";\n    case \"null\":\n      return \"z.null()\";\n    case \"undefined\":\n      return \"z.undefined()\";\n    case \"any\":\n      return \"z.any()\";\n    case \"unknown\":\n      return \"z.unknown()\";\n    case \"never\":\n      return \"z.never()\";\n    case \"nullable\":\n      return `${zodTypeToZodCode((zt as AnyZodNullable).def.innerType)}.nullable()`;\n    case \"default\": {\n      const zDefaultDef = (zt as AnyZodDefault).def;\n      return `${zodTypeToZodCode(zDefaultDef.innerType)}.default(${zDefaultDef.defaultValue})`;\n    }\n    case \"record\": {\n      const zRecordDef = (zt as AnyZodRecord).def;\n      return `z.record(${zodTypeToZodCode(zRecordDef.keyType)}, ${zodTypeToZodCode(\n        zRecordDef.valueType,\n      )})`;\n    }\n    case \"literal\": {\n      const items = Array.from((zt as z.ZodLiteral<string | number>).values).map((value) => {\n        if (typeof value === \"string\") {\n          return `\"${value}\"`;\n        }\n\n        if (value === null) {\n          return `null`;\n        }\n\n        if (value === undefined) {\n          return `undefined`;\n        }\n\n        return `${value}`;\n      });\n\n      if (items.length === 1) {\n        return `z.literal(${items[0]})`;\n      }\n      return `z.literal([${items.join(\", \")}])`;\n    }\n    case \"union\":\n      return `z.union([${(zt as AnyZodUnion).def.options\n        .map((option: z.ZodType) => zodTypeToZodCode(option))\n        .join(\",\")}])`;\n    case \"enum\":\n      // NOTE: z.enum([\"A\", \"B\"])도 z.enum({ A: \"A\", B: \"B\" })로 처리됨.\n      return `z.enum({${Object.entries((zt as z.ZodEnum).def.entries)\n        .map(([key, val]) => (typeof val === \"string\" ? `${key}: \"${val}\"` : `${key}: ${val}`))\n        .join(\", \")}})`;\n    case \"array\":\n      return `z.array(${zodTypeToZodCode((zt as z.ZodArray<z.ZodType>).def.element)})`;\n    case \"object\": {\n      const shape = (zt as AnyZodObject).shape;\n      return [\n        \"z.object({\",\n        ...Object.keys(shape).map((key) => `${key}: ${zodTypeToZodCode(shape[key])},`),\n        \"})\",\n      ].join(\"\\n\");\n    }\n    case \"optional\":\n      return `${zodTypeToZodCode((zt as z.ZodOptional<z.ZodType>).def.innerType)}.optional()`;\n    case \"file\":\n      return `z.file()`;\n    case \"template_literal\": {\n      const def = (zt as AnyZodTemplateLiteral).def;\n\n      // 빈 template literal\n      if (!def.parts || def.parts.length === 0) {\n        return \"z.templateLiteral([])\";\n      }\n\n      // 각 part를 Zod 코드 문자열로 변환\n      const parts = def.parts.map((part: unknown) => {\n        // 문자열 리터럴\n        if (typeof part === \"string\") {\n          return `\"${part}\"`;\n        }\n        // ZodType - 재귀적으로 변환\n        if (part && typeof part === \"object\" && (part as z.ZodType)._zod) {\n          return zodTypeToZodCode(part as z.ZodType);\n        }\n\n        // 폴백\n        return \"z.string()\";\n      });\n\n      return `z.templateLiteral([${parts.join(\", \")}])`;\n    }\n    case \"intersection\": {\n      const zIntersectionDef = (zt as z.ZodIntersection<z.ZodType, z.ZodType>).def;\n      return `z.intersection(${zodTypeToZodCode(zIntersectionDef.left)}, ${zodTypeToZodCode(zIntersectionDef.right)})`;\n    }\n    default:\n      throw new Error(`처리되지 않은 ZodType ${zt.def.type}`);\n  }\n}\n\n/**\n * Zod 타입을 UI 렌더링에 사용할 수 있는 RenderingNode로 변환합니다.\n * 재귀적으로 중첩된 타입들을 처리합니다.\n */\nexport function zodTypeToRenderingNode(\n  zodType: z.ZodTypeAny,\n  baseKey: string = \"root\",\n): RenderingNode {\n  const def = {\n    name: baseKey,\n    label: inflection.camelize(baseKey, false),\n    zodType,\n  };\n\n  /**\n   * 케이스 처리 순서\n   *\n   * 1. 특수 케이스 (description 기반)\n   *    - SonamuFile/SonamuFile[] : z.object/z.array이지만 파일 업로드용 내장 타입\n   *\n   * 2. 일반 케이스 (instanceof 기반)\n   *    - z.ZodObject : 일반 객체\n   *    - z.ZodArray : 일반 배열\n   *      - vector : z.array(z.number)이지만 네이밍 기반으로 벡터 임베딩\n   *      - 일반 배열 : 그 외\n   *    - z.ZodUnion, z.ZodOptional, z.ZodNullable : 유틸리티 타입\n   *    - 기타 : resolveRenderType()으로 처리\n   */\n\n  // 특수 케이스: SonamuFile[] 타입 감지\n  if (zodType.description === \"SonamuFile[]\") {\n    return { ...def, renderType: \"json-sonamufile-array\" };\n  }\n\n  // 특수 케이스: SonamuFile 단일 타입 감지\n  if (zodType.description === \"SonamuFile\") {\n    return { ...def, renderType: \"json-sonamufile\" };\n  }\n\n  // 일반 케이스: ZodObject 체크\n  if (zodType instanceof z.ZodObject) {\n    const columnKeys = Object.keys(zodType.shape);\n    const children = columnKeys.map((key) => {\n      const innerType = zodType.shape[key];\n      return zodTypeToRenderingNode(innerType, key);\n    });\n    return {\n      ...def,\n      renderType: \"object\",\n      children,\n    };\n  } else if (zodType instanceof z.ZodArray) {\n    const innerType = (zodType as z.ZodArray<z.ZodTypeAny>).def.element;\n    // vector 타입 판별: number 배열이면서 embedding, vector 등의 이름을 가진 경우\n    if (\n      innerType instanceof z.ZodNumber &&\n      (baseKey.includes(\"embedding\") || baseKey.includes(\"vector\"))\n    ) {\n      return {\n        ...def,\n        renderType: \"vector\",\n      };\n    }\n    return {\n      ...def,\n      renderType: \"array\",\n      element: zodTypeToRenderingNode(innerType, baseKey),\n    };\n  } else if (zodType instanceof z.ZodUnion) {\n    const optionNodes = (zodType as z.ZodUnion<z.ZodType[]>).def.options.map((opt) =>\n      zodTypeToRenderingNode(opt, baseKey),\n    );\n    // TODO: ZodUnion이 들어있는 경우 핸들링\n    return optionNodes[0];\n  } else if (zodType instanceof z.ZodOptional) {\n    return {\n      ...zodTypeToRenderingNode((zodType as z.ZodOptional<z.ZodType>).def.innerType, baseKey),\n      optional: true,\n    };\n  } else if (zodType instanceof z.ZodNullable) {\n    return {\n      ...zodTypeToRenderingNode((zodType as z.ZodNullable<z.ZodType>).def.innerType, baseKey),\n      nullable: true,\n    };\n  } else {\n    return {\n      ...def,\n      renderType: resolveRenderType(baseKey, zodType),\n    };\n  }\n}\n\n/**\n * Zod 타입과 키 이름으로부터 적절한 RenderType을 결정합니다.\n */\nfunction resolveRenderType(key: string, zodType: z.ZodTypeAny): RenderingNode[\"renderType\"] {\n  if (zodType instanceof z.ZodDate) {\n    return \"datetime\";\n  } else if (zodType instanceof z.ZodString) {\n    if (zodType.description === \"SQLDateTimeString\") {\n      return \"string-datetime\";\n    } else if (key.endsWith(\"date\")) {\n      return \"string-date\";\n    } else {\n      return \"string-plain\";\n    }\n  } else if (zodType instanceof z.ZodNumber) {\n    if (key === \"id\") {\n      return \"number-id\";\n    } else if (key.endsWith(\"_id\")) {\n      return \"number-fk_id\";\n    } else {\n      return \"number-plain\";\n    }\n  } else if (zodType instanceof z.ZodBoolean) {\n    return \"boolean\";\n  } else if (zodType instanceof z.ZodEnum) {\n    return \"enums\";\n  } else if (zodType instanceof z.ZodRecord) {\n    return \"record\";\n  } else if (zodType instanceof z.ZodAny || zodType instanceof z.ZodUnknown) {\n    return \"string-plain\";\n  } else if (zodType instanceof z.ZodUnion) {\n    return \"string-plain\";\n  } else if (zodType instanceof z.ZodLiteral) {\n    return \"string-plain\";\n  } else if (zodType instanceof z.ZodTemplateLiteral) {\n    return \"string-plain\";\n  } else {\n    throw new Error(`타입 파싱 불가 ${key} ${zodType.def.type}`);\n  }\n}\n"],"names":["inflection","path","z","Sonamu","EntityManager","BUILT_IN_TYPE_IDS","isBelongsToOneRelationProp","isBigIntegerArrayProp","isBigIntegerSingleProp","isBooleanArrayProp","isBooleanSingleProp","isDateArrayProp","isDateSingleProp","isEnumArrayProp","isEnumSingleProp","isIntegerArrayProp","isIntegerSingleProp","isJsonProp","isNumberArrayProp","isNumberSingleProp","isNumericArrayProp","isNumericSingleProp","isOneToOneRelationProp","isRelationProp","isStringArrayProp","isStringSingleProp","isTsVectorProp","isUuidArrayProp","isUuidSingleProp","isVectorArrayProp","isVectorSingleProp","isVirtualProp","SonamuFileArraySchema","SonamuFileSchema","createImportUrl","runtimePath","BUILT_IN_TYPES","SonamuFile","schema","renderType","schemaName","getZodTypeById","zodTypeId","includes","builtInType","Error","describe","modulePath","getModulePath","moduleAbsPath","join","apiRootPath","importUrl","imported","propToZodType","prop","zodType","unknown","number","int","array","bigint","id","length","string","max","boolean","date","uuid","hasJoinColumn","unsigned","nonnegative","nullable","propToZodTypeDef","injectImportKeys","stmt","name","push","relationType","with","propNodeToZodTypeDef","propNode","nodeType","children","map","childPropNode","zodTypeToTsTypeDef","zt","def","type","innerType","recordType","keyType","valueType","Array","from","values","value","undefined","options","option","val","element","shape","Object","keys","key","parts","part","_zod","zodTypeToZodCode","zDefaultDef","defaultValue","zRecordDef","items","entries","zIntersectionDef","left","right","zodTypeToRenderingNode","baseKey","label","camelize","description","ZodObject","columnKeys","ZodArray","ZodNumber","ZodUnion","optionNodes","opt","ZodOptional","optional","ZodNullable","resolveRenderType","ZodDate","ZodString","endsWith","ZodBoolean","ZodEnum","ZodRecord","ZodAny","ZodUnknown","ZodLiteral","ZodTemplateLiteral"],"mappings":"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"}
567
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/template/zod-converter.ts"],"sourcesContent":["/**\n * zod-converter 구성\n * 1. 유틸리티\n *  - getZodTypeById\n *\n * 2. Zod 타입 변환 (EntityProp -> ZodType)\n *  - propToZodType\n *\n * 3. EntityProp/Node -> Zod 코드 문자열\n *  - propToZodTypeDef\n *  - propNodeToZodTypeDef\n *\n * 4. Zod 타입 인스턴스를 해당하는 Zod 코드 문자열로 변환 (ZodType -> ZodCode)\n *  - zodTypeToZodCode\n *\n * 5. Zod 타입을 UI 렌더링에 사용할 수 있는 RenderingNode로 변환 (ZodType -> RenderingNode)\n *  - zodTypeToRenderingNode\n *  - resolveRenderType\n */\n\nimport inflection from \"inflection\";\nimport path from \"path\";\nimport { z } from \"zod\";\nimport type { $ZodLooseShape } from \"zod/v4/core\";\nimport { Sonamu } from \"../api/sonamu\";\nimport { EntityManager } from \"../entity/entity-manager\";\nimport {\n  BUILT_IN_TYPE_IDS,\n  type EntityProp,\n  type EntityPropNode,\n  isBelongsToOneRelationProp,\n  isBigIntegerArrayProp,\n  isBigIntegerSingleProp,\n  isBooleanArrayProp,\n  isBooleanSingleProp,\n  isDateArrayProp,\n  isDateSingleProp,\n  isEnumArrayProp,\n  isEnumSingleProp,\n  isIntegerArrayProp,\n  isIntegerSingleProp,\n  isJsonProp,\n  isNumberArrayProp,\n  isNumberSingleProp,\n  isNumericArrayProp,\n  isNumericSingleProp,\n  isOneToOneRelationProp,\n  isRelationProp,\n  isStringArrayProp,\n  isStringSingleProp,\n  isTsVectorProp,\n  isUuidArrayProp,\n  isUuidSingleProp,\n  isVectorArrayProp,\n  isVectorSingleProp,\n  isVirtualProp,\n  type RenderingNode,\n  SonamuFileArraySchema,\n  SonamuFileSchema,\n} from \"../types/types\";\nimport { createImportUrl } from \"../utils/esm-utils\";\nimport { runtimePath } from \"../utils/path-utils\";\n\n// <any>를 자제하고, Zod에서 제약하는 기본적인 Generic Type Parameter를 사용함.\ntype AnyZodRecord = z.ZodRecord<z.ZodString | z.ZodNumber | z.ZodSymbol, z.ZodType>;\ntype AnyZodObject = z.ZodObject<$ZodLooseShape>;\ntype AnyZodNullable = z.ZodNullable<z.ZodType>;\ntype AnyZodDefault = z.ZodDefault<z.ZodType>;\ntype AnyZodUnion = z.ZodUnion<z.ZodType[]>;\ntype AnyZodArray = z.ZodArray<z.ZodType>;\ntype AnyZodOptional = z.ZodOptional<z.ZodType>;\ntype AnyZodTemplateLiteral = z.ZodTemplateLiteral<string>;\n\n/**\n * 내장 타입 정의 (Zod 스키마 + UI 렌더링 타입)\n */\nexport const BUILT_IN_TYPES = {\n  SonamuFile: {\n    schema: SonamuFileSchema,\n    renderType: \"json-sonamufile\",\n    schemaName: \"SonamuFileSchema\",\n  },\n  \"SonamuFile[]\": {\n    schema: SonamuFileArraySchema,\n    renderType: \"json-sonamufile-array\",\n    schemaName: \"SonamuFileArraySchema\",\n  },\n} as const;\n\n/**\n * Zod 타입 ID로부터 동적으로 Zod 스키마를 로드합니다.\n * 내장 타입(BUILT_IN_TYPE_IDS)은 바로 반환하고,\n * 그 외는 dist 디렉토리에서 ESM으로 import하여 가져옵니다.\n */\nexport async function getZodTypeById(zodTypeId: string): Promise<z.ZodTypeAny> {\n  // 내장 타입 처리\n  if ((BUILT_IN_TYPE_IDS as readonly string[]).includes(zodTypeId)) {\n    const builtInType = BUILT_IN_TYPES[zodTypeId as keyof typeof BUILT_IN_TYPES];\n    if (!builtInType) {\n      throw new Error(`내장 타입 ${zodTypeId}의 스키마가 정의되지 않았습니다`);\n    }\n    return builtInType.schema.describe(zodTypeId);\n  }\n\n  // 프로젝트에서 정의한 타입 동적 로드\n  const modulePath = EntityManager.getModulePath(zodTypeId);\n  const moduleAbsPath = path.join(\n    Sonamu.apiRootPath,\n    runtimePath(`dist/application/${modulePath}.js`),\n  );\n  const importUrl = createImportUrl(moduleAbsPath);\n  const imported = await import(importUrl);\n\n  if (!imported[zodTypeId]) {\n    throw new Error(`존재하지 않는 zodTypeId ${zodTypeId}`);\n  }\n  return imported[zodTypeId].describe(zodTypeId);\n}\n\n/**\n * EntityProp을 Zod 타입으로 변환합니다.\n * 각 prop의 타입에 따라 적절한 Zod validator를 생성합니다.\n */\nexport async function propToZodType(prop: EntityProp): Promise<z.ZodTypeAny> {\n  let zodType: z.ZodTypeAny = z.unknown();\n  if (isIntegerSingleProp(prop)) {\n    zodType = z.number().int();\n  } else if (isIntegerArrayProp(prop)) {\n    zodType = z.number().int().array();\n  } else if (isBigIntegerSingleProp(prop)) {\n    zodType = z.bigint();\n  } else if (isBigIntegerArrayProp(prop)) {\n    zodType = z.bigint().array();\n  } else if (isEnumSingleProp(prop)) {\n    zodType = await getZodTypeById(prop.id);\n  } else if (isEnumArrayProp(prop)) {\n    zodType = (await getZodTypeById(prop.id)).array();\n  } else if (isStringSingleProp(prop)) {\n    if (prop.length) {\n      zodType = z.string().max(prop.length);\n    } else {\n      zodType = z.string();\n    }\n  } else if (isStringArrayProp(prop)) {\n    if (prop.length) {\n      zodType = z.string().max(prop.length).array();\n    } else {\n      zodType = z.string().array();\n    }\n  } else if (isNumberSingleProp(prop)) {\n    zodType = z.number();\n  } else if (isNumberArrayProp(prop)) {\n    zodType = z.number().array();\n  } else if (isNumericSingleProp(prop)) {\n    zodType = z.string();\n  } else if (isNumericArrayProp(prop)) {\n    zodType = z.string().array();\n  } else if (isBooleanSingleProp(prop)) {\n    zodType = z.boolean();\n  } else if (isBooleanArrayProp(prop)) {\n    zodType = z.boolean().array();\n  } else if (isDateSingleProp(prop)) {\n    zodType = z.date();\n  } else if (isDateArrayProp(prop)) {\n    zodType = z.date().array();\n  } else if (isUuidSingleProp(prop)) {\n    zodType = z.uuid();\n  } else if (isUuidArrayProp(prop)) {\n    zodType = z.uuid().array();\n  } else if (isJsonProp(prop)) {\n    zodType = await getZodTypeById(prop.id);\n  } else if (isVectorSingleProp(prop)) {\n    zodType = z.array(z.number());\n  } else if (isVectorArrayProp(prop)) {\n    zodType = z.array(z.array(z.number()));\n  } else if (isVirtualProp(prop)) {\n    zodType = await getZodTypeById(prop.id);\n  } else if (isRelationProp(prop)) {\n    if (isBelongsToOneRelationProp(prop) || (isOneToOneRelationProp(prop) && prop.hasJoinColumn)) {\n      zodType = z.number().int();\n    }\n  } else {\n    throw new Error(`prop을 zodType으로 변환하는데 실패 ${prop}}`);\n  }\n\n  if ((prop as { unsigned?: boolean }).unsigned) {\n    zodType = (zodType as z.ZodNumber).nonnegative();\n  }\n  if (prop.nullable) {\n    zodType = zodType.nullable();\n  }\n\n  return zodType;\n}\n\n/**\n * EntityProp을 Zod 타입 정의 코드 문자열로 변환합니다.\n */\nexport function propToZodTypeDef(prop: EntityProp, injectImportKeys: string[]): string {\n  let stmt: string;\n  if (isIntegerSingleProp(prop)) {\n    stmt = `${prop.name}: z.int()`;\n  } else if (isIntegerArrayProp(prop)) {\n    stmt = `${prop.name}: z.int().array()`;\n  } else if (isBigIntegerSingleProp(prop)) {\n    stmt = `${prop.name}: z.bigint()`;\n  } else if (isBigIntegerArrayProp(prop)) {\n    stmt = `${prop.name}: z.bigint().array()`;\n  } else if (isEnumSingleProp(prop)) {\n    stmt = `${prop.name}: ${prop.id}`;\n    injectImportKeys.push(prop.id);\n  } else if (isEnumArrayProp(prop)) {\n    stmt = `${prop.name}: ${prop.id}.array()`;\n    injectImportKeys.push(prop.id);\n  } else if (isStringSingleProp(prop)) {\n    if (prop.length) {\n      stmt = `${prop.name}: z.string().max(${prop.length})`;\n    } else {\n      stmt = `${prop.name}: z.string()`;\n    }\n  } else if (isStringArrayProp(prop)) {\n    if (prop.length) {\n      stmt = `${prop.name}: z.string().max(${prop.length}).array()`;\n    } else {\n      stmt = `${prop.name}: z.string().array()`;\n    }\n  } else if (isNumberSingleProp(prop)) {\n    stmt = `${prop.name}: z.number()`;\n  } else if (isNumberArrayProp(prop)) {\n    stmt = `${prop.name}: z.number().array()`;\n  } else if (isNumericSingleProp(prop)) {\n    stmt = `${prop.name}: z.string()`;\n  } else if (isNumericArrayProp(prop)) {\n    stmt = `${prop.name}: z.string().array()`;\n  } else if (isDateSingleProp(prop)) {\n    stmt = `${prop.name}: z.date()`;\n  } else if (isDateArrayProp(prop)) {\n    stmt = `${prop.name}: z.date().array()`;\n  } else if (isBooleanSingleProp(prop)) {\n    stmt = `${prop.name}: z.boolean()`;\n  } else if (isBooleanArrayProp(prop)) {\n    stmt = `${prop.name}: z.boolean().array()`;\n  } else if (isUuidSingleProp(prop)) {\n    stmt = `${prop.name}: z.uuid()`;\n  } else if (isUuidArrayProp(prop)) {\n    stmt = `${prop.name}: z.uuid().array()`;\n  } else if (isJsonProp(prop)) {\n    // 내장 타입인 경우 스키마 이름으로 변환\n    if ((BUILT_IN_TYPE_IDS as readonly string[]).includes(prop.id)) {\n      const schemaName = prop.id === \"SonamuFile\" ? \"SonamuFileSchema\" : \"SonamuFileArraySchema\";\n      stmt = `${prop.name}: ${schemaName}`;\n      injectImportKeys.push(schemaName);\n    } else {\n      stmt = `${prop.name}: ${prop.id}`;\n      injectImportKeys.push(prop.id);\n    }\n  } else if (isVectorSingleProp(prop)) {\n    stmt = `${prop.name}: z.array(z.number())`;\n  } else if (isVectorArrayProp(prop)) {\n    stmt = `${prop.name}: z.array(z.array(z.number()))`;\n  } else if (isTsVectorProp(prop)) {\n    stmt = `${prop.name}: z.string()`;\n  } else if (isVirtualProp(prop)) {\n    stmt = `${prop.name}: ${prop.id}`;\n    injectImportKeys.push(prop.id);\n  } else if (isRelationProp(prop)) {\n    if (isBelongsToOneRelationProp(prop) || (isOneToOneRelationProp(prop) && prop.hasJoinColumn)) {\n      stmt = `${prop.name}_id: z.int()`;\n    } else {\n      // 그외 relation 케이스 제외\n      return `// ${prop.name}: ${prop.relationType} ${prop.with}`;\n    }\n  } else {\n    return \"// unable to resolve\";\n  }\n\n  if ((prop as { unsigned?: boolean }).unsigned) {\n    stmt += \".nonnegative()\";\n  }\n  if (prop.nullable) {\n    stmt += \".nullable()\";\n  }\n\n  return `${stmt},`;\n}\n\n/**\n * EntityPropNode를 Zod 타입 정의 코드 문자열로 변환합니다.\n * plain, array, object 노드 타입을 재귀적으로 처리하여 중첩 구조를 지원합니다.\n */\nexport function propNodeToZodTypeDef(propNode: EntityPropNode, injectImportKeys: string[]): string {\n  if (propNode.nodeType === \"plain\") {\n    return propToZodTypeDef(propNode.prop, injectImportKeys);\n  } else if (propNode.nodeType === \"array\") {\n    return [\n      propNode.prop ? `${propNode.prop.name}: ` : \"\",\n      \"z.array(z.object({\",\n      propNode.children\n        .map((childPropNode) => propNodeToZodTypeDef(childPropNode, injectImportKeys))\n        .join(\"\\n\"),\n      \"\",\n      \"})),\",\n    ].join(\"\\n\");\n  } else if (propNode.nodeType === \"object\") {\n    return [\n      propNode.prop ? `${propNode.prop.name}: ` : \"\",\n      \"z.object({\",\n      propNode.children\n        .map((childPropNode) => propNodeToZodTypeDef(childPropNode, injectImportKeys))\n        .join(\"\\n\"),\n      \"\",\n      `})${propNode.prop?.nullable ? \".nullable()\" : \"\"},`,\n    ].join(\"\\n\");\n  } else {\n    throw Error;\n  }\n}\n\nexport function zodTypeToTsTypeDef(zt: z.ZodType): string {\n  switch (zt.def.type) {\n    case \"string\":\n    case \"number\":\n    case \"boolean\":\n    case \"bigint\":\n    case \"date\":\n    case \"null\":\n    case \"undefined\":\n    case \"any\":\n    case \"unknown\":\n    case \"never\":\n      return zt.def.type;\n    case \"nullable\":\n      return `${zodTypeToTsTypeDef((zt as AnyZodNullable).def.innerType)} | null`;\n    case \"default\":\n      return zodTypeToTsTypeDef((zt as AnyZodDefault).def.innerType);\n    case \"record\": {\n      const recordType = zt as AnyZodRecord;\n      return `{ [ key: ${zodTypeToTsTypeDef(recordType.def.keyType)} ]: ${zodTypeToTsTypeDef(recordType.def.valueType)}}`;\n    }\n    case \"literal\":\n      return Array.from((zt as z.ZodLiteral).values)\n        .map((value) => {\n          if (typeof value === \"string\") {\n            return `\"${value}\"`;\n          }\n\n          if (value === null) {\n            return `null`;\n          }\n\n          if (value === undefined) {\n            return `undefined`;\n          }\n\n          return `${value}`;\n        })\n        .join(\" | \");\n    case \"union\":\n      return `${(zt as AnyZodUnion).options\n        .map((option) => zodTypeToTsTypeDef(option))\n        .join(\" | \")}`;\n    case \"enum\":\n      return `${(zt as z.ZodEnum).options.map((val) => `\"${val}\"`).join(\" | \")}`;\n    case \"array\":\n      return `${zodTypeToTsTypeDef((zt as AnyZodArray).element)}[]`;\n    case \"object\": {\n      const shape = (zt as AnyZodObject).shape;\n      return [\n        \"{\",\n        ...Object.keys(shape).map((key) => {\n          if (shape[key].def.type === \"optional\") {\n            return `${key}?: ${zodTypeToTsTypeDef(shape[key].def.innerType)},`;\n          } else {\n            return `${key}: ${zodTypeToTsTypeDef(shape[key])},`;\n          }\n        }),\n        \"}\",\n      ].join(\"\\n\");\n    }\n    case \"optional\":\n      return `${zodTypeToTsTypeDef((zt as AnyZodOptional).def.innerType)} | undefined`;\n    case \"template_literal\": {\n      const def = (zt as AnyZodTemplateLiteral).def;\n\n      // 빈 template literal은 string으로 폴백\n      if (!def.parts || def.parts.length === 0) {\n        return \"string\";\n      }\n\n      // 각 part를 TypeScript 타입 문자열로 변환\n      const parts = def.parts.map((part: unknown) => {\n        // 리터럴 값 (string, number, boolean, null, undefined)\n        if (typeof part === \"string\") {\n          return `${part}`;\n        }\n\n        // ZodType - 재귀적으로 변환\n        if (part && typeof part === \"object\" && (part as z.ZodType)._zod) {\n          const innerType = zodTypeToTsTypeDef(part as z.ZodType);\n          return `$\\{${innerType}}`;\n        }\n\n        // 폴백\n        return `\\${string}`;\n      });\n\n      return `\\`${parts.join(\"\")}\\``;\n    }\n    case \"file\":\n      return \"File\";\n    default:\n      throw new Error(`처리되지 않은 ZodType ${zt.def.type}`);\n  }\n}\n\n/**\n * Zod 타입 인스턴스를 해당하는 Zod 코드 문자열로 변환합니다.\n */\nexport function zodTypeToZodCode(zt: z.ZodType): string {\n  switch (zt.def.type) {\n    case \"string\":\n      return \"z.string()\";\n    case \"number\":\n      return \"z.number()\";\n    case \"bigint\":\n      return \"z.bigint()\";\n    case \"boolean\":\n      return \"z.boolean()\";\n    case \"date\":\n      return \"z.date()\";\n    case \"null\":\n      return \"z.null()\";\n    case \"undefined\":\n      return \"z.undefined()\";\n    case \"any\":\n      return \"z.any()\";\n    case \"unknown\":\n      return \"z.unknown()\";\n    case \"never\":\n      return \"z.never()\";\n    case \"nullable\":\n      return `${zodTypeToZodCode((zt as AnyZodNullable).def.innerType)}.nullable()`;\n    case \"default\": {\n      const zDefaultDef = (zt as AnyZodDefault).def;\n      return `${zodTypeToZodCode(zDefaultDef.innerType)}.default(${zDefaultDef.defaultValue})`;\n    }\n    case \"record\": {\n      const zRecordDef = (zt as AnyZodRecord).def;\n      return `z.record(${zodTypeToZodCode(zRecordDef.keyType)}, ${zodTypeToZodCode(\n        zRecordDef.valueType,\n      )})`;\n    }\n    case \"literal\": {\n      const items = Array.from((zt as z.ZodLiteral<string | number>).values).map((value) => {\n        if (typeof value === \"string\") {\n          return `\"${value}\"`;\n        }\n\n        if (value === null) {\n          return `null`;\n        }\n\n        if (value === undefined) {\n          return `undefined`;\n        }\n\n        return `${value}`;\n      });\n\n      if (items.length === 1) {\n        return `z.literal(${items[0]})`;\n      }\n      return `z.literal([${items.join(\", \")}])`;\n    }\n    case \"union\":\n      return `z.union([${(zt as AnyZodUnion).def.options\n        .map((option: z.ZodType) => zodTypeToZodCode(option))\n        .join(\",\")}])`;\n    case \"enum\":\n      // NOTE: z.enum([\"A\", \"B\"])도 z.enum({ A: \"A\", B: \"B\" })로 처리됨.\n      return `z.enum({${Object.entries((zt as z.ZodEnum).def.entries)\n        .map(([key, val]) => (typeof val === \"string\" ? `${key}: \"${val}\"` : `${key}: ${val}`))\n        .join(\", \")}})`;\n    case \"array\":\n      return `z.array(${zodTypeToZodCode((zt as z.ZodArray<z.ZodType>).def.element)})`;\n    case \"object\": {\n      const shape = (zt as AnyZodObject).shape;\n      return [\n        \"z.object({\",\n        ...Object.keys(shape).map((key) => `${key}: ${zodTypeToZodCode(shape[key])},`),\n        \"})\",\n      ].join(\"\\n\");\n    }\n    case \"optional\":\n      return `${zodTypeToZodCode((zt as z.ZodOptional<z.ZodType>).def.innerType)}.optional()`;\n    case \"file\":\n      return `z.file()`;\n    case \"template_literal\": {\n      const def = (zt as AnyZodTemplateLiteral).def;\n\n      // 빈 template literal\n      if (!def.parts || def.parts.length === 0) {\n        return \"z.templateLiteral([])\";\n      }\n\n      // 각 part를 Zod 코드 문자열로 변환\n      const parts = def.parts.map((part: unknown) => {\n        // 문자열 리터럴\n        if (typeof part === \"string\") {\n          return `\"${part}\"`;\n        }\n        // ZodType - 재귀적으로 변환\n        if (part && typeof part === \"object\" && (part as z.ZodType)._zod) {\n          return zodTypeToZodCode(part as z.ZodType);\n        }\n\n        // 폴백\n        return \"z.string()\";\n      });\n\n      return `z.templateLiteral([${parts.join(\", \")}])`;\n    }\n    case \"intersection\": {\n      const zIntersectionDef = (zt as z.ZodIntersection<z.ZodType, z.ZodType>).def;\n      return `z.intersection(${zodTypeToZodCode(zIntersectionDef.left)}, ${zodTypeToZodCode(zIntersectionDef.right)})`;\n    }\n    default:\n      throw new Error(`처리되지 않은 ZodType ${zt.def.type}`);\n  }\n}\n\n/**\n * Zod 타입을 UI 렌더링에 사용할 수 있는 RenderingNode로 변환합니다.\n * 재귀적으로 중첩된 타입들을 처리합니다.\n */\nexport function zodTypeToRenderingNode(\n  zodType: z.ZodTypeAny,\n  baseKey: string = \"root\",\n): RenderingNode {\n  const def = {\n    name: baseKey,\n    label: inflection.camelize(baseKey, false),\n    zodType,\n  };\n\n  /**\n   * 케이스 처리 순서\n   *\n   * 1. 특수 케이스 (description 기반)\n   *    - SonamuFile/SonamuFile[] : z.object/z.array이지만 파일 업로드용 내장 타입\n   *\n   * 2. 일반 케이스 (instanceof 기반)\n   *    - z.ZodObject : 일반 객체\n   *    - z.ZodArray : 일반 배열\n   *      - vector : z.array(z.number)이지만 네이밍 기반으로 벡터 임베딩\n   *      - 일반 배열 : 그 외\n   *    - z.ZodUnion, z.ZodOptional, z.ZodNullable : 유틸리티 타입\n   *    - 기타 : resolveRenderType()으로 처리\n   */\n\n  // 특수 케이스: SonamuFile[] 타입 감지\n  if (zodType.description === \"SonamuFile[]\") {\n    return { ...def, renderType: \"json-sonamufile-array\" };\n  }\n\n  // 특수 케이스: SonamuFile 단일 타입 감지\n  if (zodType.description === \"SonamuFile\") {\n    return { ...def, renderType: \"json-sonamufile\" };\n  }\n\n  // 일반 케이스: ZodObject 체크\n  if (zodType instanceof z.ZodObject) {\n    const columnKeys = Object.keys(zodType.shape);\n    const children = columnKeys.map((key) => {\n      const innerType = zodType.shape[key];\n      return zodTypeToRenderingNode(innerType, key);\n    });\n    return {\n      ...def,\n      renderType: \"object\",\n      children,\n    };\n  } else if (zodType instanceof z.ZodArray) {\n    const innerType = (zodType as z.ZodArray<z.ZodTypeAny>).def.element;\n    // vector 타입 판별: number 배열이면서 embedding, vector 등의 이름을 가진 경우\n    if (\n      innerType instanceof z.ZodNumber &&\n      (baseKey.includes(\"embedding\") || baseKey.includes(\"vector\"))\n    ) {\n      return {\n        ...def,\n        renderType: \"vector\",\n      };\n    }\n    return {\n      ...def,\n      renderType: \"array\",\n      element: zodTypeToRenderingNode(innerType, baseKey),\n    };\n  } else if (zodType instanceof z.ZodUnion) {\n    const optionNodes = (zodType as z.ZodUnion<z.ZodType[]>).def.options.map((opt) =>\n      zodTypeToRenderingNode(opt, baseKey),\n    );\n    // TODO: ZodUnion이 들어있는 경우 핸들링\n    return optionNodes[0];\n  } else if (zodType instanceof z.ZodOptional) {\n    return {\n      ...zodTypeToRenderingNode((zodType as z.ZodOptional<z.ZodType>).def.innerType, baseKey),\n      optional: true,\n    };\n  } else if (zodType instanceof z.ZodNullable) {\n    return {\n      ...zodTypeToRenderingNode((zodType as z.ZodNullable<z.ZodType>).def.innerType, baseKey),\n      nullable: true,\n    };\n  } else {\n    return {\n      ...def,\n      renderType: resolveRenderType(baseKey, zodType),\n    };\n  }\n}\n\n/**\n * Zod 타입과 키 이름으로부터 적절한 RenderType을 결정합니다.\n */\nfunction resolveRenderType(key: string, zodType: z.ZodTypeAny): RenderingNode[\"renderType\"] {\n  if (zodType instanceof z.ZodDate) {\n    return \"datetime\";\n  } else if (zodType instanceof z.core.$ZodString) {\n    // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함\n    // FIXME: email이나 url 타입 등에 대한 처리가 필요함\n    if (zodType.description === \"SQLDateTimeString\") {\n      return \"string-datetime\";\n    } else if (key.endsWith(\"date\")) {\n      return \"string-date\";\n    } else {\n      return \"string-plain\";\n    }\n  } else if (zodType instanceof z.ZodNumber) {\n    if (key === \"id\") {\n      return \"number-id\";\n    } else if (key.endsWith(\"_id\")) {\n      return \"number-fk_id\";\n    } else {\n      return \"number-plain\";\n    }\n  } else if (zodType instanceof z.ZodBoolean) {\n    return \"boolean\";\n  } else if (zodType instanceof z.ZodEnum) {\n    return \"enums\";\n  } else if (zodType instanceof z.ZodRecord) {\n    return \"record\";\n  } else if (zodType instanceof z.ZodAny || zodType instanceof z.ZodUnknown) {\n    return \"string-plain\";\n  } else if (zodType instanceof z.ZodUnion) {\n    return \"string-plain\";\n  } else if (zodType instanceof z.ZodLiteral) {\n    return \"string-plain\";\n  } else if (zodType instanceof z.ZodTemplateLiteral) {\n    return \"string-plain\";\n  } else {\n    throw new Error(`타입 파싱 불가 ${key} ${zodType.def.type}`);\n  }\n}\n"],"names":["inflection","path","z","Sonamu","EntityManager","BUILT_IN_TYPE_IDS","isBelongsToOneRelationProp","isBigIntegerArrayProp","isBigIntegerSingleProp","isBooleanArrayProp","isBooleanSingleProp","isDateArrayProp","isDateSingleProp","isEnumArrayProp","isEnumSingleProp","isIntegerArrayProp","isIntegerSingleProp","isJsonProp","isNumberArrayProp","isNumberSingleProp","isNumericArrayProp","isNumericSingleProp","isOneToOneRelationProp","isRelationProp","isStringArrayProp","isStringSingleProp","isTsVectorProp","isUuidArrayProp","isUuidSingleProp","isVectorArrayProp","isVectorSingleProp","isVirtualProp","SonamuFileArraySchema","SonamuFileSchema","createImportUrl","runtimePath","BUILT_IN_TYPES","SonamuFile","schema","renderType","schemaName","getZodTypeById","zodTypeId","includes","builtInType","Error","describe","modulePath","getModulePath","moduleAbsPath","join","apiRootPath","importUrl","imported","propToZodType","prop","zodType","unknown","number","int","array","bigint","id","length","string","max","boolean","date","uuid","hasJoinColumn","unsigned","nonnegative","nullable","propToZodTypeDef","injectImportKeys","stmt","name","push","relationType","with","propNodeToZodTypeDef","propNode","nodeType","children","map","childPropNode","zodTypeToTsTypeDef","zt","def","type","innerType","recordType","keyType","valueType","Array","from","values","value","undefined","options","option","val","element","shape","Object","keys","key","parts","part","_zod","zodTypeToZodCode","zDefaultDef","defaultValue","zRecordDef","items","entries","zIntersectionDef","left","right","zodTypeToRenderingNode","baseKey","label","camelize","description","ZodObject","columnKeys","ZodArray","ZodNumber","ZodUnion","optionNodes","opt","ZodOptional","optional","ZodNullable","resolveRenderType","ZodDate","core","$ZodString","endsWith","ZodBoolean","ZodEnum","ZodRecord","ZodAny","ZodUnknown","ZodLiteral","ZodTemplateLiteral"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sonamu",
3
- "version": "0.7.40",
3
+ "version": "0.7.41",
4
4
  "description": "Sonamu — TypeScript Fullstack API Framework",
5
5
  "keywords": [
6
6
  "typescript",
@@ -112,10 +112,10 @@
112
112
  "vitest": "^4.0.10",
113
113
  "exceljs": "^4.4.0",
114
114
  "zod": "^4.1.12",
115
- "@sonamu-kit/hmr-runner": "^0.1.1",
116
- "@sonamu-kit/tasks": "^0.1.3",
117
115
  "@sonamu-kit/hmr-hook": "^0.4.1",
118
- "@sonamu-kit/ts-loader": "^2.1.3"
116
+ "@sonamu-kit/ts-loader": "^2.1.3",
117
+ "@sonamu-kit/hmr-runner": "^0.1.1",
118
+ "@sonamu-kit/tasks": "^0.1.3"
119
119
  },
120
120
  "devDependencies": {
121
121
  "@biomejs/biome": "^2.3.10",
@@ -75,7 +75,8 @@ export class Template__generated_http extends Template {
75
75
  );
76
76
  } else if (zodType instanceof z.ZodArray) {
77
77
  return [this.zodTypeToReqDefault((zodType as z.ZodArray<z.ZodType>).element, name)];
78
- } else if (zodType instanceof z.ZodString) {
78
+ } else if (zodType instanceof z.core.$ZodString) {
79
+ // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함
79
80
  if (name.endsWith("_at") || name.endsWith("_date") || name === "range") {
80
81
  return "2000-01-01";
81
82
  } else {
@@ -90,22 +90,33 @@ ${functions.join("\n\n")}
90
90
  );
91
91
  }
92
92
 
93
+ // tanstack-query API가 없으면 헬퍼 함수와 import를 포함하지 않습니다.
94
+ // 새 프로젝트에서 첫 빌드 시 sync가 아직 안 되어 namespace가 비어있을 수 있고,
95
+ // 이때 createSSRQuery가 unused로 빌드 에러가 발생하는 것을 방지합니다.
96
+ const hasQueries = namespaces.length > 0;
97
+
93
98
  return {
94
99
  ...this.getTargetAndPath(),
95
100
  body: namespaces.join("\n\n"),
96
101
  importKeys: diff(unique(importKeys), typeParamNames),
97
- customHeaders: [
98
- "/** biome-ignore-all lint: generated는 무시 */",
99
- "/** biome-ignore-all assist: generated는 무시 */",
100
- "",
101
- `import type { SSRQuery } from 'sonamu/ssr';`,
102
- "",
103
- `// SSRQuery 헬퍼 함수`,
104
- `function createSSRQuery(modelName: string, methodName: string, params: any[], serviceKey: [string, string]): SSRQuery {`,
105
- ` return { modelName, methodName, params, serviceKey, __brand: 'SSRQuery' } as SSRQuery;`,
106
- `}`,
107
- "",
108
- ],
102
+ customHeaders: hasQueries
103
+ ? [
104
+ "/** biome-ignore-all lint: generated는 무시 */",
105
+ "/** biome-ignore-all assist: generated는 무시 */",
106
+ "",
107
+ `import type { SSRQuery } from 'sonamu/ssr';`,
108
+ "",
109
+ `// SSRQuery 헬퍼 함수`,
110
+ `function createSSRQuery(modelName: string, methodName: string, params: any[], serviceKey: [string, string]): SSRQuery {`,
111
+ ` return { modelName, methodName, params, serviceKey, __brand: 'SSRQuery' } as SSRQuery;`,
112
+ `}`,
113
+ "",
114
+ ]
115
+ : [
116
+ "/** biome-ignore-all lint: generated는 무시 */",
117
+ "/** biome-ignore-all assist: generated는 무시 */",
118
+ "",
119
+ ],
109
120
  };
110
121
  }
111
122
  }
@@ -138,7 +138,9 @@ export class Template__view_form extends Template {
138
138
  value = Object.keys(col.zodType.enum)[0];
139
139
  } else if (col.zodType instanceof z.ZodBoolean) {
140
140
  value = false;
141
- } else if (col.zodType instanceof z.ZodString) {
141
+ } else if (col.zodType instanceof z.core.$ZodString) {
142
+ // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함
143
+ // FIXME: email이나 url 타입 등에 대한 처리가 필요함
142
144
  if (col.renderType === "string-datetime") {
143
145
  value = "now()";
144
146
  } else {
@@ -627,7 +627,9 @@ export function zodTypeToRenderingNode(
627
627
  function resolveRenderType(key: string, zodType: z.ZodTypeAny): RenderingNode["renderType"] {
628
628
  if (zodType instanceof z.ZodDate) {
629
629
  return "datetime";
630
- } else if (zodType instanceof z.ZodString) {
630
+ } else if (zodType instanceof z.core.$ZodString) {
631
+ // NOTE: z.ZodString으로 비교하면 z.url(), z.email() 등의 타입에서 문제가 생기므로 z.core.$ZodString으로 비교함
632
+ // FIXME: email이나 url 타입 등에 대한 처리가 필요함
631
633
  if (zodType.description === "SQLDateTimeString") {
632
634
  return "string-datetime";
633
635
  } else if (key.endsWith("date")) {