@tablecraft/engine 0.1.0-beta.1 → 0.1.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (307) hide show
  1. package/README.md +78 -0
  2. package/dist/core/aggregationBuilder.d.ts.map +1 -0
  3. package/dist/core/aggregationBuilder.js.map +1 -0
  4. package/dist/core/cursorPagination.d.ts.map +1 -0
  5. package/dist/core/cursorPagination.js.map +1 -0
  6. package/dist/core/datePresets.d.ts.map +1 -0
  7. package/dist/core/datePresets.js.map +1 -0
  8. package/dist/core/dialect.d.ts.map +1 -0
  9. package/dist/core/dialect.js.map +1 -0
  10. package/dist/core/fieldSelector.d.ts.map +1 -0
  11. package/dist/core/fieldSelector.js.map +1 -0
  12. package/dist/core/filterBuilder.d.ts.map +1 -0
  13. package/dist/core/filterBuilder.js.map +1 -0
  14. package/dist/core/filterGroupBuilder.d.ts.map +1 -0
  15. package/dist/core/filterGroupBuilder.js.map +1 -0
  16. package/dist/core/groupByBuilder.d.ts.map +1 -0
  17. package/dist/core/groupByBuilder.js.map +1 -0
  18. package/dist/core/inputValidator.d.ts.map +1 -0
  19. package/dist/core/inputValidator.js.map +1 -0
  20. package/dist/core/metadataBuilder.d.ts.map +1 -0
  21. package/dist/core/metadataBuilder.js.map +1 -0
  22. package/dist/core/paginationBuilder.d.ts.map +1 -0
  23. package/dist/core/paginationBuilder.js.map +1 -0
  24. package/dist/core/queryBuilder.d.ts.map +1 -0
  25. package/dist/core/queryBuilder.js.map +1 -0
  26. package/dist/core/recursiveBuilder.d.ts.map +1 -0
  27. package/dist/core/recursiveBuilder.js.map +1 -0
  28. package/dist/core/relationBuilder.d.ts.map +1 -0
  29. package/dist/core/relationBuilder.js.map +1 -0
  30. package/dist/core/roleFilter.d.ts.map +1 -0
  31. package/dist/core/roleFilter.js.map +1 -0
  32. package/dist/core/searchBuilder.d.ts.map +1 -0
  33. package/dist/core/searchBuilder.js.map +1 -0
  34. package/dist/core/softDelete.d.ts.map +1 -0
  35. package/dist/core/softDelete.js.map +1 -0
  36. package/dist/core/sortBuilder.d.ts.map +1 -0
  37. package/dist/core/sortBuilder.js.map +1 -0
  38. package/dist/core/subqueryBuilder.d.ts.map +1 -0
  39. package/dist/core/subqueryBuilder.js.map +1 -0
  40. package/dist/core/validator.d.ts.map +1 -0
  41. package/dist/core/validator.js.map +1 -0
  42. package/dist/define.d.ts.map +1 -0
  43. package/dist/define.js.map +1 -0
  44. package/dist/engine.d.ts.map +1 -0
  45. package/dist/engine.js.map +1 -0
  46. package/dist/errors.d.ts.map +1 -0
  47. package/dist/errors.js.map +1 -0
  48. package/dist/index.d.ts.map +1 -0
  49. package/dist/index.js.map +1 -0
  50. package/dist/types/engine.d.ts.map +1 -0
  51. package/dist/{src/types → types}/engine.js.map +1 -1
  52. package/dist/types/table.d.ts.map +1 -0
  53. package/dist/types/table.js.map +1 -0
  54. package/dist/utils/adapterUtils.d.ts.map +1 -0
  55. package/dist/utils/adapterUtils.js.map +1 -0
  56. package/dist/utils/codegen.d.ts.map +1 -0
  57. package/dist/utils/codegen.js.map +1 -0
  58. package/dist/utils/export.d.ts.map +1 -0
  59. package/dist/utils/export.js.map +1 -0
  60. package/dist/utils/introspect.d.ts.map +1 -0
  61. package/dist/utils/introspect.js.map +1 -0
  62. package/dist/utils/openapi.d.ts.map +1 -0
  63. package/dist/utils/openapi.js.map +1 -0
  64. package/dist/utils/operators.d.ts.map +1 -0
  65. package/dist/utils/operators.js.map +1 -0
  66. package/dist/utils/requestParser.d.ts.map +1 -0
  67. package/dist/utils/requestParser.js.map +1 -0
  68. package/dist/utils/responseFormatter.d.ts.map +1 -0
  69. package/dist/utils/responseFormatter.js.map +1 -0
  70. package/dist/utils/typedSql.d.ts.map +1 -0
  71. package/dist/utils/typedSql.js.map +1 -0
  72. package/package.json +8 -7
  73. package/dist/src/__tests__/inputValidator.test.d.ts +0 -2
  74. package/dist/src/__tests__/inputValidator.test.d.ts.map +0 -1
  75. package/dist/src/__tests__/inputValidator.test.js +0 -205
  76. package/dist/src/__tests__/inputValidator.test.js.map +0 -1
  77. package/dist/src/__tests__/metadataBuilder.test.d.ts +0 -2
  78. package/dist/src/__tests__/metadataBuilder.test.d.ts.map +0 -1
  79. package/dist/src/__tests__/metadataBuilder.test.js +0 -221
  80. package/dist/src/__tests__/metadataBuilder.test.js.map +0 -1
  81. package/dist/src/core/aggregationBuilder.d.ts.map +0 -1
  82. package/dist/src/core/aggregationBuilder.js.map +0 -1
  83. package/dist/src/core/cursorPagination.d.ts.map +0 -1
  84. package/dist/src/core/cursorPagination.js.map +0 -1
  85. package/dist/src/core/datePresets.d.ts.map +0 -1
  86. package/dist/src/core/datePresets.js.map +0 -1
  87. package/dist/src/core/dialect.d.ts.map +0 -1
  88. package/dist/src/core/dialect.js.map +0 -1
  89. package/dist/src/core/fieldSelector.d.ts.map +0 -1
  90. package/dist/src/core/fieldSelector.js.map +0 -1
  91. package/dist/src/core/filterBuilder.d.ts.map +0 -1
  92. package/dist/src/core/filterBuilder.js.map +0 -1
  93. package/dist/src/core/filterGroupBuilder.d.ts.map +0 -1
  94. package/dist/src/core/filterGroupBuilder.js.map +0 -1
  95. package/dist/src/core/groupByBuilder.d.ts.map +0 -1
  96. package/dist/src/core/groupByBuilder.js.map +0 -1
  97. package/dist/src/core/inputValidator.d.ts.map +0 -1
  98. package/dist/src/core/inputValidator.js.map +0 -1
  99. package/dist/src/core/metadataBuilder.d.ts.map +0 -1
  100. package/dist/src/core/metadataBuilder.js.map +0 -1
  101. package/dist/src/core/paginationBuilder.d.ts.map +0 -1
  102. package/dist/src/core/paginationBuilder.js.map +0 -1
  103. package/dist/src/core/queryBuilder.d.ts.map +0 -1
  104. package/dist/src/core/queryBuilder.js.map +0 -1
  105. package/dist/src/core/recursiveBuilder.d.ts.map +0 -1
  106. package/dist/src/core/recursiveBuilder.js.map +0 -1
  107. package/dist/src/core/relationBuilder.d.ts.map +0 -1
  108. package/dist/src/core/relationBuilder.js.map +0 -1
  109. package/dist/src/core/roleFilter.d.ts.map +0 -1
  110. package/dist/src/core/roleFilter.js.map +0 -1
  111. package/dist/src/core/searchBuilder.d.ts.map +0 -1
  112. package/dist/src/core/searchBuilder.js.map +0 -1
  113. package/dist/src/core/softDelete.d.ts.map +0 -1
  114. package/dist/src/core/softDelete.js.map +0 -1
  115. package/dist/src/core/sortBuilder.d.ts.map +0 -1
  116. package/dist/src/core/sortBuilder.js.map +0 -1
  117. package/dist/src/core/subqueryBuilder.d.ts.map +0 -1
  118. package/dist/src/core/subqueryBuilder.js.map +0 -1
  119. package/dist/src/core/validator.d.ts.map +0 -1
  120. package/dist/src/core/validator.js.map +0 -1
  121. package/dist/src/define.d.ts.map +0 -1
  122. package/dist/src/define.js.map +0 -1
  123. package/dist/src/engine.d.ts.map +0 -1
  124. package/dist/src/engine.js.map +0 -1
  125. package/dist/src/errors.d.ts.map +0 -1
  126. package/dist/src/errors.js.map +0 -1
  127. package/dist/src/index.d.ts.map +0 -1
  128. package/dist/src/index.js.map +0 -1
  129. package/dist/src/types/engine.d.ts.map +0 -1
  130. package/dist/src/types/table.d.ts.map +0 -1
  131. package/dist/src/types/table.js.map +0 -1
  132. package/dist/src/utils/adapterUtils.d.ts.map +0 -1
  133. package/dist/src/utils/adapterUtils.js.map +0 -1
  134. package/dist/src/utils/codegen.d.ts.map +0 -1
  135. package/dist/src/utils/codegen.js.map +0 -1
  136. package/dist/src/utils/export.d.ts.map +0 -1
  137. package/dist/src/utils/export.js.map +0 -1
  138. package/dist/src/utils/introspect.d.ts.map +0 -1
  139. package/dist/src/utils/introspect.js.map +0 -1
  140. package/dist/src/utils/openapi.d.ts.map +0 -1
  141. package/dist/src/utils/openapi.js.map +0 -1
  142. package/dist/src/utils/operators.d.ts.map +0 -1
  143. package/dist/src/utils/operators.js.map +0 -1
  144. package/dist/src/utils/requestParser.d.ts.map +0 -1
  145. package/dist/src/utils/requestParser.js.map +0 -1
  146. package/dist/src/utils/responseFormatter.d.ts.map +0 -1
  147. package/dist/src/utils/responseFormatter.js.map +0 -1
  148. package/dist/src/utils/typedSql.d.ts.map +0 -1
  149. package/dist/src/utils/typedSql.js.map +0 -1
  150. package/dist/test/columnMeta.test.d.ts +0 -2
  151. package/dist/test/columnMeta.test.d.ts.map +0 -1
  152. package/dist/test/columnMeta.test.js +0 -92
  153. package/dist/test/columnMeta.test.js.map +0 -1
  154. package/dist/test/core/aggregationBuilder.test.d.ts +0 -2
  155. package/dist/test/core/aggregationBuilder.test.d.ts.map +0 -1
  156. package/dist/test/core/aggregationBuilder.test.js +0 -64
  157. package/dist/test/core/aggregationBuilder.test.js.map +0 -1
  158. package/dist/test/core/filterBuilder.test.d.ts +0 -2
  159. package/dist/test/core/filterBuilder.test.d.ts.map +0 -1
  160. package/dist/test/core/filterBuilder.test.js +0 -80
  161. package/dist/test/core/filterBuilder.test.js.map +0 -1
  162. package/dist/test/core/paginationBuilder.test.d.ts +0 -2
  163. package/dist/test/core/paginationBuilder.test.d.ts.map +0 -1
  164. package/dist/test/core/paginationBuilder.test.js +0 -63
  165. package/dist/test/core/paginationBuilder.test.js.map +0 -1
  166. package/dist/test/core/queryBuilder.test.d.ts +0 -2
  167. package/dist/test/core/queryBuilder.test.d.ts.map +0 -1
  168. package/dist/test/core/queryBuilder.test.js +0 -92
  169. package/dist/test/core/queryBuilder.test.js.map +0 -1
  170. package/dist/test/core/searchBuilder.test.d.ts +0 -2
  171. package/dist/test/core/searchBuilder.test.d.ts.map +0 -1
  172. package/dist/test/core/searchBuilder.test.js +0 -68
  173. package/dist/test/core/searchBuilder.test.js.map +0 -1
  174. package/dist/test/core/softDelete.test.d.ts +0 -2
  175. package/dist/test/core/softDelete.test.d.ts.map +0 -1
  176. package/dist/test/core/softDelete.test.js +0 -60
  177. package/dist/test/core/softDelete.test.js.map +0 -1
  178. package/dist/test/core/sortBuilder.test.d.ts +0 -2
  179. package/dist/test/core/sortBuilder.test.d.ts.map +0 -1
  180. package/dist/test/core/sortBuilder.test.js +0 -59
  181. package/dist/test/core/sortBuilder.test.js.map +0 -1
  182. package/dist/test/core/subqueryBuilder.test.d.ts +0 -2
  183. package/dist/test/core/subqueryBuilder.test.d.ts.map +0 -1
  184. package/dist/test/core/subqueryBuilder.test.js +0 -48
  185. package/dist/test/core/subqueryBuilder.test.js.map +0 -1
  186. package/dist/test/core/validator.test.d.ts +0 -2
  187. package/dist/test/core/validator.test.d.ts.map +0 -1
  188. package/dist/test/core/validator.test.js +0 -81
  189. package/dist/test/core/validator.test.js.map +0 -1
  190. package/dist/test/datePresets.test.d.ts +0 -2
  191. package/dist/test/datePresets.test.d.ts.map +0 -1
  192. package/dist/test/datePresets.test.js +0 -57
  193. package/dist/test/datePresets.test.js.map +0 -1
  194. package/dist/test/errors.test.d.ts +0 -2
  195. package/dist/test/errors.test.d.ts.map +0 -1
  196. package/dist/test/errors.test.js +0 -62
  197. package/dist/test/errors.test.js.map +0 -1
  198. package/dist/test/inputValidator.test.d.ts +0 -2
  199. package/dist/test/inputValidator.test.d.ts.map +0 -1
  200. package/dist/test/inputValidator.test.js +0 -60
  201. package/dist/test/inputValidator.test.js.map +0 -1
  202. package/dist/test/metadata.test.d.ts +0 -2
  203. package/dist/test/metadata.test.d.ts.map +0 -1
  204. package/dist/test/metadata.test.js +0 -285
  205. package/dist/test/metadata.test.js.map +0 -1
  206. package/dist/test/metadataComplete.test.d.ts +0 -2
  207. package/dist/test/metadataComplete.test.d.ts.map +0 -1
  208. package/dist/test/metadataComplete.test.js +0 -113
  209. package/dist/test/metadataComplete.test.js.map +0 -1
  210. package/dist/test/roleFilter.test.d.ts +0 -2
  211. package/dist/test/roleFilter.test.d.ts.map +0 -1
  212. package/dist/test/roleFilter.test.js +0 -53
  213. package/dist/test/roleFilter.test.js.map +0 -1
  214. package/dist/test/typedSql.test.d.ts +0 -2
  215. package/dist/test/typedSql.test.d.ts.map +0 -1
  216. package/dist/test/typedSql.test.js +0 -63
  217. package/dist/test/typedSql.test.js.map +0 -1
  218. package/dist/test/utils/codegen.test.d.ts +0 -2
  219. package/dist/test/utils/codegen.test.d.ts.map +0 -1
  220. package/dist/test/utils/codegen.test.js +0 -65
  221. package/dist/test/utils/codegen.test.js.map +0 -1
  222. package/dist/test/utils/export.test.d.ts +0 -2
  223. package/dist/test/utils/export.test.d.ts.map +0 -1
  224. package/dist/test/utils/export.test.js +0 -54
  225. package/dist/test/utils/export.test.js.map +0 -1
  226. package/dist/test/utils/openapi.test.d.ts +0 -2
  227. package/dist/test/utils/openapi.test.d.ts.map +0 -1
  228. package/dist/test/utils/openapi.test.js +0 -65
  229. package/dist/test/utils/openapi.test.js.map +0 -1
  230. package/dist/test/utils/requestParser.test.d.ts +0 -2
  231. package/dist/test/utils/requestParser.test.d.ts.map +0 -1
  232. package/dist/test/utils/requestParser.test.js +0 -89
  233. package/dist/test/utils/requestParser.test.js.map +0 -1
  234. package/dist/test/utils/responseFormatter.test.d.ts +0 -2
  235. package/dist/test/utils/responseFormatter.test.d.ts.map +0 -1
  236. package/dist/test/utils/responseFormatter.test.js +0 -79
  237. package/dist/test/utils/responseFormatter.test.js.map +0 -1
  238. /package/dist/{src/core → core}/aggregationBuilder.d.ts +0 -0
  239. /package/dist/{src/core → core}/aggregationBuilder.js +0 -0
  240. /package/dist/{src/core → core}/cursorPagination.d.ts +0 -0
  241. /package/dist/{src/core → core}/cursorPagination.js +0 -0
  242. /package/dist/{src/core → core}/datePresets.d.ts +0 -0
  243. /package/dist/{src/core → core}/datePresets.js +0 -0
  244. /package/dist/{src/core → core}/dialect.d.ts +0 -0
  245. /package/dist/{src/core → core}/dialect.js +0 -0
  246. /package/dist/{src/core → core}/fieldSelector.d.ts +0 -0
  247. /package/dist/{src/core → core}/fieldSelector.js +0 -0
  248. /package/dist/{src/core → core}/filterBuilder.d.ts +0 -0
  249. /package/dist/{src/core → core}/filterBuilder.js +0 -0
  250. /package/dist/{src/core → core}/filterGroupBuilder.d.ts +0 -0
  251. /package/dist/{src/core → core}/filterGroupBuilder.js +0 -0
  252. /package/dist/{src/core → core}/groupByBuilder.d.ts +0 -0
  253. /package/dist/{src/core → core}/groupByBuilder.js +0 -0
  254. /package/dist/{src/core → core}/inputValidator.d.ts +0 -0
  255. /package/dist/{src/core → core}/inputValidator.js +0 -0
  256. /package/dist/{src/core → core}/metadataBuilder.d.ts +0 -0
  257. /package/dist/{src/core → core}/metadataBuilder.js +0 -0
  258. /package/dist/{src/core → core}/paginationBuilder.d.ts +0 -0
  259. /package/dist/{src/core → core}/paginationBuilder.js +0 -0
  260. /package/dist/{src/core → core}/queryBuilder.d.ts +0 -0
  261. /package/dist/{src/core → core}/queryBuilder.js +0 -0
  262. /package/dist/{src/core → core}/recursiveBuilder.d.ts +0 -0
  263. /package/dist/{src/core → core}/recursiveBuilder.js +0 -0
  264. /package/dist/{src/core → core}/relationBuilder.d.ts +0 -0
  265. /package/dist/{src/core → core}/relationBuilder.js +0 -0
  266. /package/dist/{src/core → core}/roleFilter.d.ts +0 -0
  267. /package/dist/{src/core → core}/roleFilter.js +0 -0
  268. /package/dist/{src/core → core}/searchBuilder.d.ts +0 -0
  269. /package/dist/{src/core → core}/searchBuilder.js +0 -0
  270. /package/dist/{src/core → core}/softDelete.d.ts +0 -0
  271. /package/dist/{src/core → core}/softDelete.js +0 -0
  272. /package/dist/{src/core → core}/sortBuilder.d.ts +0 -0
  273. /package/dist/{src/core → core}/sortBuilder.js +0 -0
  274. /package/dist/{src/core → core}/subqueryBuilder.d.ts +0 -0
  275. /package/dist/{src/core → core}/subqueryBuilder.js +0 -0
  276. /package/dist/{src/core → core}/validator.d.ts +0 -0
  277. /package/dist/{src/core → core}/validator.js +0 -0
  278. /package/dist/{src/define.d.ts → define.d.ts} +0 -0
  279. /package/dist/{src/define.js → define.js} +0 -0
  280. /package/dist/{src/engine.d.ts → engine.d.ts} +0 -0
  281. /package/dist/{src/engine.js → engine.js} +0 -0
  282. /package/dist/{src/errors.d.ts → errors.d.ts} +0 -0
  283. /package/dist/{src/errors.js → errors.js} +0 -0
  284. /package/dist/{src/index.d.ts → index.d.ts} +0 -0
  285. /package/dist/{src/index.js → index.js} +0 -0
  286. /package/dist/{src/types → types}/engine.d.ts +0 -0
  287. /package/dist/{src/types → types}/engine.js +0 -0
  288. /package/dist/{src/types → types}/table.d.ts +0 -0
  289. /package/dist/{src/types → types}/table.js +0 -0
  290. /package/dist/{src/utils → utils}/adapterUtils.d.ts +0 -0
  291. /package/dist/{src/utils → utils}/adapterUtils.js +0 -0
  292. /package/dist/{src/utils → utils}/codegen.d.ts +0 -0
  293. /package/dist/{src/utils → utils}/codegen.js +0 -0
  294. /package/dist/{src/utils → utils}/export.d.ts +0 -0
  295. /package/dist/{src/utils → utils}/export.js +0 -0
  296. /package/dist/{src/utils → utils}/introspect.d.ts +0 -0
  297. /package/dist/{src/utils → utils}/introspect.js +0 -0
  298. /package/dist/{src/utils → utils}/openapi.d.ts +0 -0
  299. /package/dist/{src/utils → utils}/openapi.js +0 -0
  300. /package/dist/{src/utils → utils}/operators.d.ts +0 -0
  301. /package/dist/{src/utils → utils}/operators.js +0 -0
  302. /package/dist/{src/utils → utils}/requestParser.d.ts +0 -0
  303. /package/dist/{src/utils → utils}/requestParser.js +0 -0
  304. /package/dist/{src/utils → utils}/responseFormatter.d.ts +0 -0
  305. /package/dist/{src/utils → utils}/responseFormatter.js +0 -0
  306. /package/dist/{src/utils → utils}/typedSql.d.ts +0 -0
  307. /package/dist/{src/utils → utils}/typedSql.js +0 -0
@@ -1,285 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import { buildMetadata } from '../src/core/metadataBuilder';
3
- // ── Simple config (base columns only) ──
4
- const simpleConfig = {
5
- name: 'orders',
6
- base: 'orders',
7
- columns: [
8
- { name: 'id', type: 'uuid', hidden: false, sortable: true, filterable: true },
9
- { name: 'total', type: 'number', label: 'Total', hidden: false, sortable: true, filterable: true,
10
- format: 'currency', align: 'right', width: 120 },
11
- { name: 'status', type: 'string', label: 'Status', hidden: false, sortable: true, filterable: true,
12
- options: [
13
- { value: 'active', label: 'Active', color: 'green' },
14
- { value: 'inactive', label: 'Inactive', color: 'gray' },
15
- ] },
16
- { name: 'createdAt', type: 'date', label: 'Created', hidden: false, sortable: true, filterable: true,
17
- datePresets: ['today', 'last7days', 'thisMonth'] },
18
- { name: 'salary', type: 'number', hidden: false, sortable: true, filterable: true,
19
- visibleTo: ['admin', 'hr'] },
20
- { name: 'secret', type: 'string', hidden: true, sortable: false, filterable: false },
21
- ],
22
- search: { fields: ['status'], enabled: true },
23
- pagination: { defaultPageSize: 25, maxPageSize: 100, enabled: true },
24
- defaultSort: [{ field: 'createdAt', order: 'desc' }],
25
- export: { formats: ['csv', 'json'], enabled: true },
26
- };
27
- // ── Complex config (joins, computed, aggregations, includes, groupBy, recursive, static filters) ──
28
- const complexConfig = {
29
- name: 'ordersDashboard',
30
- base: 'orders',
31
- columns: [
32
- { name: 'id', type: 'uuid', hidden: false, sortable: true, filterable: true },
33
- { name: 'total', type: 'number', label: 'Total', hidden: false, sortable: true, filterable: true },
34
- { name: 'status', type: 'string', label: 'Status', hidden: false, sortable: true, filterable: true },
35
- // Computed column (added via .computed())
36
- { name: 'fullName', type: 'string', label: 'Full Name', hidden: false, sortable: true, filterable: false, computed: true },
37
- ],
38
- joins: [
39
- {
40
- table: 'customers',
41
- type: 'left',
42
- on: 'orders.customerId = customers.id',
43
- columns: [
44
- { name: 'customerName', type: 'string', label: 'Customer', hidden: false, sortable: true, filterable: true },
45
- { name: 'customerEmail', type: 'string', label: 'Email', hidden: false, sortable: false, filterable: true },
46
- ],
47
- // Nested join
48
- joins: [
49
- {
50
- table: 'regions',
51
- type: 'left',
52
- on: 'customers.regionId = regions.id',
53
- columns: [
54
- { name: 'regionName', type: 'string', label: 'Region', hidden: false, sortable: true, filterable: true },
55
- ],
56
- },
57
- ],
58
- },
59
- ],
60
- subqueries: [
61
- { alias: 'itemCount', table: 'orderItems', type: 'count', filter: 'orderItems.orderId = orders.id' },
62
- { alias: 'hasReturns', table: 'returns', type: 'exists', filter: 'returns.orderId = orders.id' },
63
- ],
64
- aggregations: [
65
- { alias: 'totalRevenue', type: 'sum', field: 'total' },
66
- { alias: 'avgOrderValue', type: 'avg', field: 'total' },
67
- { alias: 'orderCount', type: 'count', field: 'id' },
68
- ],
69
- include: [
70
- {
71
- table: 'orderItems',
72
- foreignKey: 'orderId',
73
- localKey: 'id',
74
- as: 'items',
75
- columns: ['name', 'qty', 'price'],
76
- include: [
77
- {
78
- table: 'products',
79
- foreignKey: 'productId',
80
- localKey: 'id',
81
- as: 'product',
82
- columns: ['sku', 'name'],
83
- },
84
- ],
85
- },
86
- {
87
- table: 'comments',
88
- foreignKey: 'orderId',
89
- localKey: 'id',
90
- as: 'comments',
91
- },
92
- ],
93
- groupBy: {
94
- fields: ['status', 'customerId'],
95
- having: [{ alias: 'orderCount', operator: 'gt', value: 5 }],
96
- },
97
- recursive: {
98
- parentKey: 'parentOrderId',
99
- childKey: 'id',
100
- maxDepth: 5,
101
- depthAlias: 'depth',
102
- },
103
- filters: [
104
- { field: 'status', operator: 'eq', value: 'active', type: 'static' },
105
- ],
106
- backendConditions: [
107
- { field: 'deletedAt', operator: 'isNull', value: null },
108
- ],
109
- search: { fields: ['status'], enabled: true },
110
- pagination: { defaultPageSize: 25, maxPageSize: 100, enabled: true },
111
- defaultSort: [{ field: 'createdAt', order: 'desc' }],
112
- export: { formats: ['csv', 'json'], enabled: true },
113
- };
114
- describe('buildMetadata — simple config', () => {
115
- it('should build metadata without context (no role filtering)', () => {
116
- const meta = buildMetadata(simpleConfig);
117
- expect(meta.name).toBe('orders');
118
- // salary has visibleTo but no user roles → hidden
119
- const salaryCol = meta.columns.find(c => c.name === 'salary');
120
- expect(salaryCol).toBeUndefined();
121
- // secret is hidden → not in metadata
122
- const secretCol = meta.columns.find(c => c.name === 'secret');
123
- expect(secretCol).toBeUndefined();
124
- });
125
- it('should show salary to admin role', () => {
126
- const meta = buildMetadata(simpleConfig, {
127
- user: { id: '1', roles: ['admin'] },
128
- });
129
- const salaryCol = meta.columns.find(c => c.name === 'salary');
130
- expect(salaryCol).toBeDefined();
131
- });
132
- it('should hide salary from viewer role', () => {
133
- const meta = buildMetadata(simpleConfig, {
134
- user: { id: '1', roles: ['viewer'] },
135
- });
136
- const salaryCol = meta.columns.find(c => c.name === 'salary');
137
- expect(salaryCol).toBeUndefined();
138
- });
139
- it('should include format metadata', () => {
140
- const meta = buildMetadata(simpleConfig, { user: { id: '1', roles: ['admin'] } });
141
- const totalCol = meta.columns.find(c => c.name === 'total');
142
- expect(totalCol.format).toBe('currency');
143
- expect(totalCol.align).toBe('right');
144
- expect(totalCol.width).toBe(120);
145
- });
146
- it('should include enum options', () => {
147
- const meta = buildMetadata(simpleConfig);
148
- const statusCol = meta.columns.find(c => c.name === 'status');
149
- expect(statusCol.options).toHaveLength(2);
150
- expect(statusCol.options[0]).toEqual({ value: 'active', label: 'Active', color: 'green' });
151
- });
152
- it('should include date presets', () => {
153
- const meta = buildMetadata(simpleConfig);
154
- const dateCol = meta.columns.find(c => c.name === 'createdAt');
155
- expect(dateCol.datePresets).toEqual(['today', 'last7days', 'thisMonth']);
156
- });
157
- it('should include correct operators per type', () => {
158
- const meta = buildMetadata(simpleConfig);
159
- const idCol = meta.columns.find(c => c.name === 'id');
160
- expect(idCol.operators).toContain('eq');
161
- expect(idCol.operators).toContain('in');
162
- const totalCol = meta.columns.find(c => c.name === 'total');
163
- expect(totalCol.operators).toContain('gt');
164
- expect(totalCol.operators).toContain('between');
165
- const statusCol = meta.columns.find(c => c.name === 'status');
166
- expect(statusCol.operators).toContain('contains');
167
- });
168
- it('should include capabilities', () => {
169
- const meta = buildMetadata(simpleConfig);
170
- expect(meta.capabilities.search).toBe(true);
171
- expect(meta.capabilities.searchFields).toEqual(['status']);
172
- expect(meta.capabilities.export).toBe(true);
173
- expect(meta.capabilities.pagination.defaultPageSize).toBe(25);
174
- expect(meta.capabilities.sort.defaultSort).toEqual([{ field: 'createdAt', order: 'desc' }]);
175
- expect(meta.capabilities.groupBy).toBe(false);
176
- expect(meta.capabilities.recursive).toBe(false);
177
- });
178
- it('should include filter metadata', () => {
179
- const meta = buildMetadata(simpleConfig);
180
- const statusFilter = meta.filters.find(f => f.field === 'status');
181
- expect(statusFilter).toBeDefined();
182
- expect(statusFilter.options).toHaveLength(2);
183
- expect(statusFilter.operators).toContain('contains');
184
- });
185
- it('should have empty aggregations, includes, staticFilters for simple config', () => {
186
- const meta = buildMetadata(simpleConfig);
187
- expect(meta.aggregations).toEqual([]);
188
- expect(meta.includes).toEqual([]);
189
- expect(meta.staticFilters).toEqual([]);
190
- });
191
- it('should mark base columns with source "base"', () => {
192
- const meta = buildMetadata(simpleConfig);
193
- const idCol = meta.columns.find(c => c.name === 'id');
194
- expect(idCol.source).toBe('base');
195
- expect(idCol.computed).toBe(false);
196
- });
197
- });
198
- describe('buildMetadata — complex config (joins, computed, aggregations, includes)', () => {
199
- it('should include join columns from joined tables', () => {
200
- const meta = buildMetadata(complexConfig);
201
- const customerNameCol = meta.columns.find(c => c.name === 'customerName');
202
- expect(customerNameCol).toBeDefined();
203
- expect(customerNameCol.source).toBe('join');
204
- expect(customerNameCol.joinTable).toBe('customers');
205
- expect(customerNameCol.label).toBe('Customer');
206
- expect(customerNameCol.filterable).toBe(true);
207
- });
208
- it('should include nested join columns', () => {
209
- const meta = buildMetadata(complexConfig);
210
- const regionCol = meta.columns.find(c => c.name === 'regionName');
211
- expect(regionCol).toBeDefined();
212
- expect(regionCol.source).toBe('join');
213
- expect(regionCol.joinTable).toBe('regions');
214
- });
215
- it('should include computed columns with correct source', () => {
216
- const meta = buildMetadata(complexConfig);
217
- const fullNameCol = meta.columns.find(c => c.name === 'fullName');
218
- expect(fullNameCol).toBeDefined();
219
- expect(fullNameCol.source).toBe('computed');
220
- expect(fullNameCol.computed).toBe(true);
221
- expect(fullNameCol.filterable).toBe(false);
222
- });
223
- it('should include subquery virtual columns', () => {
224
- const meta = buildMetadata(complexConfig);
225
- const itemCountCol = meta.columns.find(c => c.name === 'itemCount');
226
- expect(itemCountCol).toBeDefined();
227
- expect(itemCountCol.source).toBe('subquery');
228
- expect(itemCountCol.type).toBe('number');
229
- const hasReturnsCol = meta.columns.find(c => c.name === 'hasReturns');
230
- expect(hasReturnsCol).toBeDefined();
231
- expect(hasReturnsCol.source).toBe('subquery');
232
- expect(hasReturnsCol.type).toBe('boolean');
233
- });
234
- it('should include aggregation metadata', () => {
235
- const meta = buildMetadata(complexConfig);
236
- expect(meta.aggregations).toHaveLength(3);
237
- expect(meta.aggregations[0]).toEqual({ alias: 'totalRevenue', type: 'sum', field: 'total' });
238
- expect(meta.aggregations[1]).toEqual({ alias: 'avgOrderValue', type: 'avg', field: 'total' });
239
- expect(meta.aggregations[2]).toEqual({ alias: 'orderCount', type: 'count', field: 'id' });
240
- });
241
- it('should include nested relation metadata (includes)', () => {
242
- const meta = buildMetadata(complexConfig);
243
- expect(meta.includes).toHaveLength(2);
244
- const items = meta.includes.find(i => i.as === 'items');
245
- expect(items).toBeDefined();
246
- expect(items.table).toBe('orderItems');
247
- expect(items.columns).toEqual(['name', 'qty', 'price']);
248
- expect(items.nested).toHaveLength(1);
249
- expect(items.nested[0].as).toBe('product');
250
- expect(items.nested[0].table).toBe('products');
251
- expect(items.nested[0].columns).toEqual(['sku', 'name']);
252
- const comments = meta.includes.find(i => i.as === 'comments');
253
- expect(comments).toBeDefined();
254
- expect(comments.table).toBe('comments');
255
- expect(comments.nested).toBeUndefined();
256
- });
257
- it('should expose groupBy capabilities', () => {
258
- const meta = buildMetadata(complexConfig);
259
- expect(meta.capabilities.groupBy).toBe(true);
260
- expect(meta.capabilities.groupByFields).toEqual(['status', 'customerId']);
261
- });
262
- it('should expose recursive capability', () => {
263
- const meta = buildMetadata(complexConfig);
264
- expect(meta.capabilities.recursive).toBe(true);
265
- });
266
- it('should expose static filters and backend conditions', () => {
267
- const meta = buildMetadata(complexConfig);
268
- expect(meta.staticFilters).toContain('status');
269
- expect(meta.staticFilters).toContain('deletedAt');
270
- expect(meta.staticFilters).toHaveLength(2);
271
- });
272
- it('should include join columns in filterable filters list', () => {
273
- const meta = buildMetadata(complexConfig);
274
- const customerFilter = meta.filters.find(f => f.field === 'customerName');
275
- expect(customerFilter).toBeDefined();
276
- expect(customerFilter.type).toBe('string');
277
- expect(customerFilter.operators).toContain('contains');
278
- });
279
- it('should count total columns from all sources', () => {
280
- const meta = buildMetadata(complexConfig);
281
- // 4 base + 3 join (customerName, customerEmail, regionName) + 2 subquery (itemCount, hasReturns) = 9
282
- expect(meta.columns).toHaveLength(9);
283
- });
284
- });
285
- //# sourceMappingURL=metadata.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"metadata.test.js","sourceRoot":"","sources":["../../test/metadata.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAG5D,0CAA0C;AAE1C,MAAM,YAAY,GAAgB;IAChC,IAAI,EAAE,QAAQ;IACd,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE;QACP,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;QAC7E,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI;YAC9F,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAS;QACzD,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI;YAChG,OAAO,EAAE;gBACP,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE;gBACpD,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE;aACxD,EAAS;QACZ,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI;YAClG,WAAW,EAAE,CAAC,OAAO,EAAE,WAAW,EAAE,WAAW,CAAC,EAAS;QAC3D,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI;YAC/E,SAAS,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,EAAS;QACrC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE;KACrF;IACD,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE;IAC7C,UAAU,EAAE,EAAE,eAAe,EAAE,EAAE,EAAE,WAAW,EAAE,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE;IACpE,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;IACpD,MAAM,EAAE,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE;CACpD,CAAC;AAEF,qGAAqG;AAErG,MAAM,aAAa,GAAgB;IACjC,IAAI,EAAE,iBAAiB;IACvB,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE;QACP,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;QAC7E,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;QAClG,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;QACpG,0CAA0C;QAC1C,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC3H;IACD,KAAK,EAAE;QACL;YACE,KAAK,EAAE,WAAW;YAClB,IAAI,EAAE,MAAM;YACZ,EAAE,EAAE,kCAAkC;YACtC,OAAO,EAAE;gBACP,EAAE,IAAI,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;gBAC5G,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE;aAC5G;YACD,cAAc;YACd,KAAK,EAAE;gBACL;oBACE,KAAK,EAAE,SAAS;oBAChB,IAAI,EAAE,MAAM;oBACZ,EAAE,EAAE,iCAAiC;oBACrC,OAAO,EAAE;wBACP,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;qBACzG;iBACF;aACF;SACF;KACF;IACD,UAAU,EAAE;QACV,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,gCAAgC,EAAE;QACpG,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,6BAA6B,EAAE;KACjG;IACD,YAAY,EAAE;QACZ,EAAE,KAAK,EAAE,cAAc,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE;QACtD,EAAE,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE;QACvD,EAAE,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE;KACpD;IACD,OAAO,EAAE;QACP;YACE,KAAK,EAAE,YAAY;YACnB,UAAU,EAAE,SAAS;YACrB,QAAQ,EAAE,IAAI;YACd,EAAE,EAAE,OAAO;YACX,OAAO,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC;YACjC,OAAO,EAAE;gBACP;oBACE,KAAK,EAAE,UAAU;oBACjB,UAAU,EAAE,WAAW;oBACvB,QAAQ,EAAE,IAAI;oBACd,EAAE,EAAE,SAAS;oBACb,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC;iBACzB;aACF;SACF;QACD;YACE,KAAK,EAAE,UAAU;YACjB,UAAU,EAAE,SAAS;YACrB,QAAQ,EAAE,IAAI;YACd,EAAE,EAAE,UAAU;SACf;KACF;IACD,OAAO,EAAE;QACP,MAAM,EAAE,CAAC,QAAQ,EAAE,YAAY,CAAC;QAChC,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;KAC5D;IACD,SAAS,EAAE;QACT,SAAS,EAAE,eAAe;QAC1B,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,CAAC;QACX,UAAU,EAAE,OAAO;KACpB;IACD,OAAO,EAAE;QACP,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE;KACrE;IACD,iBAAiB,EAAE;QACjB,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE;KACxD;IACD,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE;IAC7C,UAAU,EAAE,EAAE,eAAe,EAAE,EAAE,EAAE,WAAW,EAAE,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE;IACpE,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;IACpD,MAAM,EAAE,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE;CACpD,CAAC;AAEF,QAAQ,CAAC,+BAA+B,EAAE,GAAG,EAAE;IAC7C,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,kDAAkD;QAClD,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QAC9D,MAAM,CAAC,SAAS,CAAC,CAAC,aAAa,EAAE,CAAC;QAElC,qCAAqC;QACrC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QAC9D,MAAM,CAAC,SAAS,CAAC,CAAC,aAAa,EAAE,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,EAAE;YACvC,IAAI,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,OAAO,CAAC,EAAE;SACpC,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QAC9D,MAAM,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,EAAE;YACvC,IAAI,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE;SACrC,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QAC9D,MAAM,CAAC,SAAS,CAAC,CAAC,aAAa,EAAE,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QAElF,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAE,CAAC;QAC7D,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACzC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACrC,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAE,CAAC;QAC/D,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,CAAC,SAAS,CAAC,OAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;IAC9F,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACrC,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,CAAE,CAAC;QAChE,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAE,CAAC;QACvD,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACxC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAE,CAAC;QAC7D,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC3C,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEhD,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAE,CAAC;QAC/D,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACrC,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC3D,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC9D,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;QAC5F,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC;QAClE,MAAM,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;QACnC,MAAM,CAAC,YAAa,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,YAAa,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2EAA2E,EAAE,GAAG,EAAE;QACnF,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACtC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAClC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC;QAEzC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAE,CAAC;QACvD,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,0EAA0E,EAAE,GAAG,EAAE;IACxF,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,cAAc,CAAC,CAAC;QAC1E,MAAM,CAAC,eAAe,CAAC,CAAC,WAAW,EAAE,CAAC;QACtC,MAAM,CAAC,eAAgB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7C,MAAM,CAAC,eAAgB,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACrD,MAAM,CAAC,eAAgB,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,CAAC,eAAgB,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;QAClE,MAAM,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QAChC,MAAM,CAAC,SAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvC,MAAM,CAAC,SAAU,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;QAClE,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,CAAC;QAClC,MAAM,CAAC,WAAY,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7C,MAAM,CAAC,WAAY,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,WAAY,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;QACnC,MAAM,CAAC,YAAa,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC9C,MAAM,CAAC,YAAa,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE1C,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;QACtE,MAAM,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;QACpC,MAAM,CAAC,aAAc,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC/C,MAAM,CAAC,aAAc,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;QAC7F,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;QAC9F,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IAC5F,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAEtC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;QACxD,MAAM,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5B,MAAM,CAAC,KAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACxC,MAAM,CAAC,KAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,KAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,KAAM,CAAC,MAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7C,MAAM,CAAC,KAAM,CAAC,MAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjD,MAAM,CAAC,KAAM,CAAC,MAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;QAE3D,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,UAAU,CAAC,CAAC;QAC9D,MAAM,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/B,MAAM,CAAC,QAAS,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACzC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;QAChE,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,cAAc,CAAC,CAAC;QAC1E,MAAM,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,CAAC,cAAe,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,CAAC,cAAe,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1C,qGAAqG;QACrG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=metadataComplete.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"metadataComplete.test.d.ts","sourceRoot":"","sources":["../../test/metadataComplete.test.ts"],"names":[],"mappings":""}
@@ -1,113 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import { buildMetadata } from '../src/core/metadataBuilder';
3
- const config = {
4
- name: 'orders',
5
- base: 'orders',
6
- columns: [
7
- { name: 'id', type: 'uuid', hidden: false, sortable: true, filterable: true },
8
- { name: 'total', type: 'number', label: 'Total', hidden: false, sortable: true, filterable: true,
9
- format: 'currency', align: 'right' },
10
- { name: 'status', type: 'string', label: 'Status', hidden: false, sortable: true, filterable: true,
11
- options: [
12
- { value: 'active', label: 'Active', color: 'green' },
13
- { value: 'pending', label: 'Pending', color: 'yellow' },
14
- ] },
15
- { name: 'profit', type: 'number', hidden: false, sortable: true, filterable: true,
16
- visibleTo: ['admin'] },
17
- ],
18
- joins: [
19
- { table: 'customers', type: 'left', on: 'orders.customerId = customers.id',
20
- columns: [{ name: 'customerName', type: 'string', hidden: false, sortable: true, filterable: true }] },
21
- ],
22
- subqueries: [{ alias: 'itemCount', table: 'orderItems', type: 'count', filter: 'orderId = orders.id' }],
23
- filters: [
24
- { field: 'status', operator: 'eq', type: 'dynamic' },
25
- { field: 'archived', operator: 'eq', value: false, type: 'static' },
26
- ],
27
- backendConditions: [
28
- { field: 'tenantId', operator: 'eq', value: '$tenantId' },
29
- ],
30
- search: { fields: ['status', 'customerName'], enabled: true },
31
- pagination: { defaultPageSize: 25, maxPageSize: 100, enabled: true },
32
- defaultSort: [{ field: 'createdAt', order: 'desc' }],
33
- aggregations: [
34
- { alias: 'totalRevenue', type: 'sum', field: 'total' },
35
- { alias: 'orderCount', type: 'count', field: 'id' },
36
- ],
37
- include: [
38
- { table: 'orderItems', foreignKey: 'orderId', as: 'items', localKey: 'id', columns: ['qty', 'price'] },
39
- ],
40
- groupBy: { fields: ['status'] },
41
- export: { formats: ['csv', 'json'], enabled: true },
42
- };
43
- describe('buildMetadata — complete response', () => {
44
- it('should include source field for join columns', () => {
45
- const meta = buildMetadata(config, { user: { id: '1', roles: ['admin'] } });
46
- const nameCol = meta.columns.find((c) => c.name === 'customerName');
47
- expect(nameCol.source).toBe('join');
48
- expect(nameCol.joinTable).toBe('customers');
49
- });
50
- it('should include aggregations array', () => {
51
- const meta = buildMetadata(config);
52
- expect(meta.aggregations).toHaveLength(2);
53
- expect(meta.aggregations[0]).toEqual({ alias: 'totalRevenue', type: 'sum', field: 'total' });
54
- expect(meta.aggregations[1]).toEqual({ alias: 'orderCount', type: 'count', field: 'id' });
55
- });
56
- it('should include includes array', () => {
57
- const meta = buildMetadata(config);
58
- expect(meta.includes).toHaveLength(1);
59
- expect(meta.includes[0]).toEqual({
60
- as: 'items',
61
- table: 'orderItems',
62
- columns: ['qty', 'price'],
63
- });
64
- });
65
- it('should include staticFilters', () => {
66
- const meta = buildMetadata(config);
67
- expect(meta.staticFilters).toContain('archived');
68
- expect(meta.staticFilters).toContain('tenantId');
69
- });
70
- it('should include groupBy in capabilities', () => {
71
- const meta = buildMetadata(config);
72
- expect(meta.capabilities.groupBy).toBe(true);
73
- expect(meta.capabilities.groupByFields).toEqual(['status']);
74
- });
75
- it('should set recursive false when not configured', () => {
76
- const meta = buildMetadata(config);
77
- expect(meta.capabilities.recursive).toBe(false);
78
- });
79
- it('should set recursive true when configured', () => {
80
- const recursiveConfig = {
81
- ...config,
82
- recursive: { parentKey: 'parentId', childKey: 'id', maxDepth: 10, depthAlias: 'depth' },
83
- };
84
- const meta = buildMetadata(recursiveConfig);
85
- expect(meta.capabilities.recursive).toBe(true);
86
- });
87
- it('should include format and align in column metadata', () => {
88
- const meta = buildMetadata(config, { user: { id: '1', roles: ['admin'] } });
89
- const totalCol = meta.columns.find((c) => c.name === 'total');
90
- expect(totalCol.format).toBe('currency');
91
- expect(totalCol.align).toBe('right');
92
- });
93
- it('should include enum options in filters', () => {
94
- const meta = buildMetadata(config);
95
- const statusFilter = meta.filters.find((f) => f.field === 'status');
96
- expect(statusFilter.options).toHaveLength(2);
97
- expect(statusFilter.options[0].value).toBe('active');
98
- });
99
- it('should mark subquery columns with correct source', () => {
100
- const meta = buildMetadata(config, { user: { id: '1', roles: ['admin'] } });
101
- const itemCountCol = meta.columns.find((c) => c.name === 'itemCount');
102
- expect(itemCountCol).toBeDefined();
103
- expect(itemCountCol.source).toBe('subquery');
104
- expect(itemCountCol.type).toBe('number');
105
- });
106
- it('should hide role-restricted columns from unauthorized users', () => {
107
- const viewerMeta = buildMetadata(config, { user: { id: '1', roles: ['viewer'] } });
108
- expect(viewerMeta.columns.find((c) => c.name === 'profit')).toBeUndefined();
109
- const adminMeta = buildMetadata(config, { user: { id: '1', roles: ['admin'] } });
110
- expect(adminMeta.columns.find((c) => c.name === 'profit')).toBeDefined();
111
- });
112
- });
113
- //# sourceMappingURL=metadataComplete.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"metadataComplete.test.js","sourceRoot":"","sources":["../../test/metadataComplete.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=roleFilter.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"roleFilter.test.d.ts","sourceRoot":"","sources":["../../test/roleFilter.test.ts"],"names":[],"mappings":""}
@@ -1,53 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import { applyRoleBasedVisibility } from '../src/core/roleFilter';
3
- const config = {
4
- name: 'employees',
5
- base: 'employees',
6
- columns: [
7
- { name: 'id', type: 'uuid', hidden: false, sortable: true, filterable: true },
8
- { name: 'name', type: 'string', hidden: false, sortable: true, filterable: true },
9
- { name: 'email', type: 'string', hidden: false, sortable: true, filterable: true },
10
- { name: 'salary', type: 'number', hidden: false, sortable: true, filterable: true,
11
- visibleTo: ['admin', 'hr'] },
12
- { name: 'ssn', type: 'string', hidden: false, sortable: false, filterable: false,
13
- visibleTo: ['admin'] },
14
- { name: 'notes', type: 'string', hidden: false, sortable: false, filterable: false },
15
- ],
16
- };
17
- describe('applyRoleBasedVisibility', () => {
18
- it('should show all unrestricted columns to everyone', () => {
19
- const result = applyRoleBasedVisibility(config, { user: { id: '1', roles: [] } });
20
- expect(result.columns.find(c => c.name === 'name').hidden).toBe(false);
21
- expect(result.columns.find(c => c.name === 'email').hidden).toBe(false);
22
- expect(result.columns.find(c => c.name === 'notes').hidden).toBe(false);
23
- });
24
- it('should hide salary from non-admin/hr', () => {
25
- const result = applyRoleBasedVisibility(config, { user: { id: '1', roles: ['viewer'] } });
26
- expect(result.columns.find(c => c.name === 'salary').hidden).toBe(true);
27
- });
28
- it('should show salary to admin', () => {
29
- const result = applyRoleBasedVisibility(config, { user: { id: '1', roles: ['admin'] } });
30
- expect(result.columns.find(c => c.name === 'salary').hidden).toBe(false);
31
- });
32
- it('should show salary to hr', () => {
33
- const result = applyRoleBasedVisibility(config, { user: { id: '1', roles: ['hr'] } });
34
- expect(result.columns.find(c => c.name === 'salary').hidden).toBe(false);
35
- });
36
- it('should show ssn only to admin', () => {
37
- const hrResult = applyRoleBasedVisibility(config, { user: { id: '1', roles: ['hr'] } });
38
- expect(hrResult.columns.find(c => c.name === 'ssn').hidden).toBe(true);
39
- const adminResult = applyRoleBasedVisibility(config, { user: { id: '1', roles: ['admin'] } });
40
- expect(adminResult.columns.find(c => c.name === 'ssn').hidden).toBe(false);
41
- });
42
- it('should hide restricted columns when no context', () => {
43
- const result = applyRoleBasedVisibility(config, {});
44
- expect(result.columns.find(c => c.name === 'salary').hidden).toBe(true);
45
- expect(result.columns.find(c => c.name === 'ssn').hidden).toBe(true);
46
- });
47
- it('should not mutate original config', () => {
48
- const result = applyRoleBasedVisibility(config, { user: { id: '1', roles: [] } });
49
- expect(config.columns.find(c => c.name === 'salary').hidden).toBe(false); // original unchanged
50
- expect(result.columns.find(c => c.name === 'salary').hidden).toBe(true); // copy changed
51
- });
52
- });
53
- //# sourceMappingURL=roleFilter.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"roleFilter.test.js","sourceRoot":"","sources":["../../test/roleFilter.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=typedSql.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"typedSql.test.d.ts","sourceRoot":"","sources":["../../test/typedSql.test.ts"],"names":[],"mappings":""}
@@ -1,63 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import { column, caseWhen, coalesce, concat, dateTrunc, interval, ago } from '../src/utils/typedSql';
3
- import { pgTable, uuid, varchar, integer, timestamp } from 'drizzle-orm/pg-core';
4
- const users = pgTable('users', {
5
- id: uuid('id').primaryKey(),
6
- name: varchar('name', { length: 255 }),
7
- nickname: varchar('nickname', { length: 255 }),
8
- status: integer('status'),
9
- createdAt: timestamp('created_at'),
10
- });
11
- describe('column', () => {
12
- it('should return a valid column', () => {
13
- const col = column(users, 'name');
14
- expect(col).toBeDefined();
15
- });
16
- it('should throw for invalid column', () => {
17
- // @ts-expect-error - testing runtime failure
18
- expect(() => column(users, 'nonexistent')).toThrow();
19
- });
20
- });
21
- describe('caseWhen', () => {
22
- it('should build a CASE expression', () => {
23
- const col = column(users, 'status');
24
- const result = caseWhen(col, { 1: 'active', 2: 'inactive' }, 'unknown');
25
- expect(result).toBeDefined();
26
- });
27
- it('should build without fallback', () => {
28
- const col = column(users, 'status');
29
- const result = caseWhen(col, { 1: 'yes', 0: 'no' });
30
- expect(result).toBeDefined();
31
- });
32
- });
33
- describe('coalesce', () => {
34
- it('should build COALESCE with columns', () => {
35
- const result = coalesce(column(users, 'nickname'), column(users, 'name'), 'Anonymous');
36
- expect(result).toBeDefined();
37
- });
38
- });
39
- describe('concat', () => {
40
- it('should build CONCAT', () => {
41
- const result = concat(column(users, 'name'), ' - ', column(users, 'nickname'));
42
- expect(result).toBeDefined();
43
- });
44
- });
45
- describe('dateTrunc', () => {
46
- it('should build DATE_TRUNC', () => {
47
- const result = dateTrunc('month', column(users, 'createdAt'));
48
- expect(result).toBeDefined();
49
- });
50
- });
51
- describe('interval', () => {
52
- it('should build INTERVAL', () => {
53
- const result = interval(30, 'days');
54
- expect(result).toBeDefined();
55
- });
56
- });
57
- describe('ago', () => {
58
- it('should build NOW() - INTERVAL', () => {
59
- const result = ago(30, 'days');
60
- expect(result).toBeDefined();
61
- });
62
- });
63
- //# sourceMappingURL=typedSql.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"typedSql.test.js","sourceRoot":"","sources":["../../test/typedSql.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=codegen.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"codegen.test.d.ts","sourceRoot":"","sources":["../../../test/utils/codegen.test.ts"],"names":[],"mappings":""}