@neogroup/neorm 0.0.1 → 0.0.3

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 (344) hide show
  1. package/README.md +36 -35
  2. package/dist/database/Connection.d.ts +10 -0
  3. package/dist/database/Connection.js +3 -0
  4. package/dist/database/Connection.js.map +1 -0
  5. package/dist/database/DB.d.ts +63 -0
  6. package/dist/database/DB.js +247 -0
  7. package/dist/database/DB.js.map +1 -0
  8. package/dist/database/DataConnection.d.ts +24 -0
  9. package/dist/database/DataConnection.js +99 -0
  10. package/dist/database/DataConnection.js.map +1 -0
  11. package/dist/database/DataSet.d.ts +3 -0
  12. package/dist/database/DataSet.js +3 -0
  13. package/dist/database/DataSet.js.map +1 -0
  14. package/dist/database/DataSource.d.ts +23 -0
  15. package/dist/database/DataSource.js +56 -0
  16. package/dist/database/DataSource.js.map +1 -0
  17. package/dist/database/DataTable.d.ts +19 -0
  18. package/dist/database/DataTable.js +75 -0
  19. package/dist/database/DataTable.js.map +1 -0
  20. package/dist/database/index.d.ts +8 -0
  21. package/dist/database/index.js +25 -0
  22. package/dist/database/index.js.map +1 -0
  23. package/dist/database/query/DeleteQuery.d.ts +8 -0
  24. package/dist/database/query/DeleteQuery.js +17 -0
  25. package/dist/database/query/DeleteQuery.js.map +1 -0
  26. package/dist/database/query/InsertQuery.d.ts +8 -0
  27. package/dist/database/query/InsertQuery.js +17 -0
  28. package/dist/database/query/InsertQuery.js.map +1 -0
  29. package/dist/database/query/Query.d.ts +2 -0
  30. package/dist/database/query/Query.js +7 -0
  31. package/dist/database/query/Query.js.map +1 -0
  32. package/dist/database/query/QueryTable.d.ts +7 -0
  33. package/dist/database/query/QueryTable.js +3 -0
  34. package/dist/database/query/QueryTable.js.map +1 -0
  35. package/dist/database/query/SelectQuery.d.ts +9 -0
  36. package/dist/database/query/SelectQuery.js +33 -0
  37. package/dist/database/query/SelectQuery.js.map +1 -0
  38. package/dist/database/query/Statement.d.ts +4 -0
  39. package/dist/database/query/Statement.js +3 -0
  40. package/dist/database/query/Statement.js.map +1 -0
  41. package/dist/database/query/UpdateQuery.d.ts +8 -0
  42. package/dist/database/query/UpdateQuery.js +17 -0
  43. package/dist/database/query/UpdateQuery.js.map +1 -0
  44. package/dist/database/query/builders/DefaultQueryBuilder.d.ts +87 -0
  45. package/dist/database/query/builders/DefaultQueryBuilder.js +524 -0
  46. package/dist/database/query/builders/DefaultQueryBuilder.js.map +1 -0
  47. package/dist/database/query/builders/QueryBuilder.d.ts +5 -0
  48. package/dist/database/query/builders/QueryBuilder.js +7 -0
  49. package/dist/database/query/builders/QueryBuilder.js.map +1 -0
  50. package/dist/database/query/builders/index.d.ts +2 -0
  51. package/dist/database/query/builders/index.js +19 -0
  52. package/dist/database/query/builders/index.js.map +1 -0
  53. package/dist/database/query/conditions/BasicCondition.d.ts +6 -0
  54. package/dist/database/query/conditions/BasicCondition.js +3 -0
  55. package/dist/database/query/conditions/BasicCondition.js.map +1 -0
  56. package/dist/database/query/conditions/ColumnCondition.d.ts +6 -0
  57. package/dist/database/query/conditions/ColumnCondition.js +3 -0
  58. package/dist/database/query/conditions/ColumnCondition.js.map +1 -0
  59. package/dist/database/query/conditions/Condition.d.ts +5 -0
  60. package/dist/database/query/conditions/Condition.js +3 -0
  61. package/dist/database/query/conditions/Condition.js.map +1 -0
  62. package/dist/database/query/conditions/ConditionConnector.d.ts +4 -0
  63. package/dist/database/query/conditions/ConditionConnector.js +9 -0
  64. package/dist/database/query/conditions/ConditionConnector.js.map +1 -0
  65. package/dist/database/query/conditions/ConditionGroup.d.ts +40 -0
  66. package/dist/database/query/conditions/ConditionGroup.js +138 -0
  67. package/dist/database/query/conditions/ConditionGroup.js.map +1 -0
  68. package/dist/database/query/conditions/ConnectedCondition.d.ts +6 -0
  69. package/dist/database/query/conditions/ConnectedCondition.js +3 -0
  70. package/dist/database/query/conditions/ConnectedCondition.js.map +1 -0
  71. package/dist/database/query/conditions/RawCondition.d.ts +4 -0
  72. package/dist/database/query/conditions/RawCondition.js +3 -0
  73. package/dist/database/query/conditions/RawCondition.js.map +1 -0
  74. package/dist/database/query/conditions/index.d.ts +7 -0
  75. package/dist/database/query/conditions/index.js +24 -0
  76. package/dist/database/query/conditions/index.js.map +1 -0
  77. package/dist/database/query/features/HasAlias.d.ts +6 -0
  78. package/dist/database/query/features/HasAlias.js +17 -0
  79. package/dist/database/query/features/HasAlias.js.map +1 -0
  80. package/dist/database/query/features/HasDistinct.d.ts +6 -0
  81. package/dist/database/query/features/HasDistinct.js +20 -0
  82. package/dist/database/query/features/HasDistinct.js.map +1 -0
  83. package/dist/database/query/features/HasFieldValues.d.ts +9 -0
  84. package/dist/database/query/features/HasFieldValues.js +27 -0
  85. package/dist/database/query/features/HasFieldValues.js.map +1 -0
  86. package/dist/database/query/features/HasGroupByFields.d.ts +7 -0
  87. package/dist/database/query/features/HasGroupByFields.js +21 -0
  88. package/dist/database/query/features/HasGroupByFields.js.map +1 -0
  89. package/dist/database/query/features/HasHavingConditions.d.ts +13 -0
  90. package/dist/database/query/features/HasHavingConditions.js +28 -0
  91. package/dist/database/query/features/HasHavingConditions.js.map +1 -0
  92. package/dist/database/query/features/HasJoins.d.ts +41 -0
  93. package/dist/database/query/features/HasJoins.js +66 -0
  94. package/dist/database/query/features/HasJoins.js.map +1 -0
  95. package/dist/database/query/features/HasLimit.d.ts +6 -0
  96. package/dist/database/query/features/HasLimit.js +20 -0
  97. package/dist/database/query/features/HasLimit.js.map +1 -0
  98. package/dist/database/query/features/HasOffset.d.ts +6 -0
  99. package/dist/database/query/features/HasOffset.js +20 -0
  100. package/dist/database/query/features/HasOffset.js.map +1 -0
  101. package/dist/database/query/features/HasOrderByFields.d.ts +15 -0
  102. package/dist/database/query/features/HasOrderByFields.js +38 -0
  103. package/dist/database/query/features/HasOrderByFields.js.map +1 -0
  104. package/dist/database/query/features/HasSelectFields.d.ts +11 -0
  105. package/dist/database/query/features/HasSelectFields.js +21 -0
  106. package/dist/database/query/features/HasSelectFields.js.map +1 -0
  107. package/dist/database/query/features/HasTable.d.ts +7 -0
  108. package/dist/database/query/features/HasTable.js +20 -0
  109. package/dist/database/query/features/HasTable.js.map +1 -0
  110. package/dist/database/query/features/HasUnions.d.ts +13 -0
  111. package/dist/database/query/features/HasUnions.js +21 -0
  112. package/dist/database/query/features/HasUnions.js.map +1 -0
  113. package/dist/database/query/features/HasWhen.d.ts +3 -0
  114. package/dist/database/query/features/HasWhen.js +13 -0
  115. package/dist/database/query/features/HasWhen.js.map +1 -0
  116. package/dist/database/query/features/HasWhereConditions.d.ts +35 -0
  117. package/dist/database/query/features/HasWhereConditions.js +92 -0
  118. package/dist/database/query/features/HasWhereConditions.js.map +1 -0
  119. package/dist/database/query/features/index.d.ts +14 -0
  120. package/dist/database/query/features/index.js +31 -0
  121. package/dist/database/query/features/index.js.map +1 -0
  122. package/dist/database/query/fields/BasicField.d.ts +5 -0
  123. package/dist/database/query/fields/BasicField.js +3 -0
  124. package/dist/database/query/fields/BasicField.js.map +1 -0
  125. package/dist/database/query/fields/Field.d.ts +3 -0
  126. package/dist/database/query/fields/Field.js +3 -0
  127. package/dist/database/query/fields/Field.js.map +1 -0
  128. package/dist/database/query/fields/RawField.d.ts +1 -0
  129. package/dist/database/query/fields/RawField.js +3 -0
  130. package/dist/database/query/fields/RawField.js.map +1 -0
  131. package/dist/database/query/fields/index.d.ts +3 -0
  132. package/dist/database/query/fields/index.js +20 -0
  133. package/dist/database/query/fields/index.js.map +1 -0
  134. package/dist/database/query/index.d.ts +11 -0
  135. package/dist/database/query/index.js +28 -0
  136. package/dist/database/query/index.js.map +1 -0
  137. package/dist/database/sources/index.d.ts +3 -0
  138. package/dist/database/sources/index.js +20 -0
  139. package/dist/database/sources/index.js.map +1 -0
  140. package/dist/database/sources/mysql/MysqlConnection.d.ts +14 -0
  141. package/dist/database/sources/mysql/MysqlConnection.js +36 -0
  142. package/dist/database/sources/mysql/MysqlConnection.js.map +1 -0
  143. package/dist/database/sources/mysql/MysqlDataSource.d.ts +24 -0
  144. package/dist/database/sources/mysql/MysqlDataSource.js +72 -0
  145. package/dist/database/sources/mysql/MysqlDataSource.js.map +1 -0
  146. package/dist/database/sources/mysql/MysqlQueryBuilder.d.ts +6 -0
  147. package/dist/database/sources/mysql/MysqlQueryBuilder.js +28 -0
  148. package/dist/database/sources/mysql/MysqlQueryBuilder.js.map +1 -0
  149. package/dist/database/sources/mysql/index.d.ts +3 -0
  150. package/dist/database/sources/mysql/index.js +20 -0
  151. package/dist/database/sources/mysql/index.js.map +1 -0
  152. package/dist/database/sources/postgres/PostgresConnection.d.ts +13 -0
  153. package/dist/database/sources/postgres/PostgresConnection.js +40 -0
  154. package/dist/database/sources/postgres/PostgresConnection.js.map +1 -0
  155. package/dist/database/sources/postgres/PostgresDataSource.d.ts +24 -0
  156. package/dist/database/sources/postgres/PostgresDataSource.js +73 -0
  157. package/dist/database/sources/postgres/PostgresDataSource.js.map +1 -0
  158. package/dist/database/sources/postgres/PostgresQueryBuilder.d.ts +5 -0
  159. package/dist/database/sources/postgres/PostgresQueryBuilder.js +13 -0
  160. package/dist/database/sources/postgres/PostgresQueryBuilder.js.map +1 -0
  161. package/dist/database/sources/postgres/index.d.ts +2 -0
  162. package/dist/database/sources/postgres/index.js +19 -0
  163. package/dist/database/sources/postgres/index.js.map +1 -0
  164. package/dist/database/sources/sqlite/SqliteConnection.d.ts +14 -0
  165. package/dist/database/sources/sqlite/SqliteConnection.js +37 -0
  166. package/dist/database/sources/sqlite/SqliteConnection.js.map +1 -0
  167. package/dist/database/sources/sqlite/SqliteDataSource.d.ts +11 -0
  168. package/dist/database/sources/sqlite/SqliteDataSource.js +34 -0
  169. package/dist/database/sources/sqlite/SqliteDataSource.js.map +1 -0
  170. package/dist/database/sources/sqlite/SqliteQueryBuilder.d.ts +6 -0
  171. package/dist/database/sources/sqlite/SqliteQueryBuilder.js +23 -0
  172. package/dist/database/sources/sqlite/SqliteQueryBuilder.js.map +1 -0
  173. package/dist/database/sources/sqlite/index.d.ts +3 -0
  174. package/dist/database/sources/sqlite/index.js +20 -0
  175. package/dist/database/sources/sqlite/index.js.map +1 -0
  176. package/dist/entities/BaseEntity.d.ts +76 -0
  177. package/dist/entities/BaseEntity.js +208 -0
  178. package/dist/entities/BaseEntity.js.map +1 -0
  179. package/dist/entities/CastType.d.ts +1 -0
  180. package/dist/entities/CastType.js +3 -0
  181. package/dist/entities/CastType.js.map +1 -0
  182. package/dist/entities/Entities.d.ts +14 -0
  183. package/dist/entities/Entities.js +85 -0
  184. package/dist/entities/Entities.js.map +1 -0
  185. package/dist/entities/EntityQuery.d.ts +60 -0
  186. package/dist/entities/EntityQuery.js +305 -0
  187. package/dist/entities/EntityQuery.js.map +1 -0
  188. package/dist/entities/RelationshipType.d.ts +1 -0
  189. package/dist/entities/RelationshipType.js +3 -0
  190. package/dist/entities/RelationshipType.js.map +1 -0
  191. package/dist/entities/decorators/BelongsTo.d.ts +2 -0
  192. package/dist/entities/decorators/BelongsTo.js +15 -0
  193. package/dist/entities/decorators/BelongsTo.js.map +1 -0
  194. package/dist/entities/decorators/Column.d.ts +13 -0
  195. package/dist/entities/decorators/Column.js +12 -0
  196. package/dist/entities/decorators/Column.js.map +1 -0
  197. package/dist/entities/decorators/Entity.d.ts +20 -0
  198. package/dist/entities/decorators/Entity.js +50 -0
  199. package/dist/entities/decorators/Entity.js.map +1 -0
  200. package/dist/entities/decorators/HasMany.d.ts +2 -0
  201. package/dist/entities/decorators/HasMany.js +15 -0
  202. package/dist/entities/decorators/HasMany.js.map +1 -0
  203. package/dist/entities/decorators/HasManyThrough.d.ts +2 -0
  204. package/dist/entities/decorators/HasManyThrough.js +23 -0
  205. package/dist/entities/decorators/HasManyThrough.js.map +1 -0
  206. package/dist/entities/decorators/HasOne.d.ts +2 -0
  207. package/dist/entities/decorators/HasOne.js +12 -0
  208. package/dist/entities/decorators/HasOne.js.map +1 -0
  209. package/dist/entities/decorators/HasOneThrough.d.ts +2 -0
  210. package/dist/entities/decorators/HasOneThrough.js +23 -0
  211. package/dist/entities/decorators/HasOneThrough.js.map +1 -0
  212. package/dist/entities/decorators/casts.d.ts +3 -0
  213. package/dist/entities/decorators/casts.js +38 -0
  214. package/dist/entities/decorators/casts.js.map +1 -0
  215. package/dist/entities/decorators/index.d.ts +7 -0
  216. package/dist/entities/decorators/index.js +24 -0
  217. package/dist/entities/decorators/index.js.map +1 -0
  218. package/dist/entities/decorators/metadata.d.ts +19 -0
  219. package/dist/entities/decorators/metadata.js +12 -0
  220. package/dist/entities/decorators/metadata.js.map +1 -0
  221. package/dist/entities/index.d.ts +5 -3
  222. package/dist/entities/index.js +5 -2
  223. package/dist/entities/index.js.map +1 -1
  224. package/dist/entities/relationship.d.ts +1 -6
  225. package/dist/entities/relationship.js +1 -22
  226. package/dist/entities/relationship.js.map +1 -1
  227. package/dist/index.d.ts +1 -9
  228. package/dist/index.js +1 -14
  229. package/dist/index.js.map +1 -1
  230. package/dist/query/DeleteQuery.d.ts +8 -0
  231. package/dist/query/DeleteQuery.js +17 -0
  232. package/dist/query/DeleteQuery.js.map +1 -0
  233. package/dist/query/InsertQuery.d.ts +8 -0
  234. package/dist/query/InsertQuery.js +17 -0
  235. package/dist/query/InsertQuery.js.map +1 -0
  236. package/dist/query/QueryTable.d.ts +7 -0
  237. package/dist/query/QueryTable.js +3 -0
  238. package/dist/query/QueryTable.js.map +1 -0
  239. package/dist/query/SelectQuery.d.ts +9 -0
  240. package/dist/query/SelectQuery.js +33 -0
  241. package/dist/query/SelectQuery.js.map +1 -0
  242. package/dist/query/UpdateQuery.d.ts +8 -0
  243. package/dist/query/UpdateQuery.js +17 -0
  244. package/dist/query/UpdateQuery.js.map +1 -0
  245. package/dist/query/builders/DefaultQueryBuilder.d.ts +87 -0
  246. package/dist/query/builders/DefaultQueryBuilder.js +524 -0
  247. package/dist/query/builders/DefaultQueryBuilder.js.map +1 -0
  248. package/dist/query/builders/QueryBuilder.d.ts +5 -0
  249. package/dist/query/builders/QueryBuilder.js +7 -0
  250. package/dist/query/builders/QueryBuilder.js.map +1 -0
  251. package/dist/query/builders/index.d.ts +2 -2
  252. package/dist/query/builders/index.js +2 -2
  253. package/dist/query/builders/index.js.map +1 -1
  254. package/dist/query/conditions/BasicCondition.d.ts +6 -0
  255. package/dist/query/conditions/BasicCondition.js +3 -0
  256. package/dist/query/conditions/BasicCondition.js.map +1 -0
  257. package/dist/query/conditions/ColumnCondition.d.ts +6 -0
  258. package/dist/query/conditions/ColumnCondition.js +3 -0
  259. package/dist/query/conditions/ColumnCondition.js.map +1 -0
  260. package/dist/query/conditions/Condition.d.ts +5 -0
  261. package/dist/query/conditions/Condition.js +3 -0
  262. package/dist/query/conditions/Condition.js.map +1 -0
  263. package/dist/query/conditions/ConditionConnector.d.ts +4 -0
  264. package/dist/query/conditions/ConditionConnector.js +9 -0
  265. package/dist/query/conditions/ConditionConnector.js.map +1 -0
  266. package/dist/query/conditions/ConditionGroup.d.ts +40 -0
  267. package/dist/query/conditions/ConditionGroup.js +138 -0
  268. package/dist/query/conditions/ConditionGroup.js.map +1 -0
  269. package/dist/query/conditions/ConnectedCondition.d.ts +6 -0
  270. package/dist/query/conditions/ConnectedCondition.js +3 -0
  271. package/dist/query/conditions/ConnectedCondition.js.map +1 -0
  272. package/dist/query/conditions/RawCondition.d.ts +4 -0
  273. package/dist/query/conditions/RawCondition.js +3 -0
  274. package/dist/query/conditions/RawCondition.js.map +1 -0
  275. package/dist/query/conditions/index.d.ts +7 -0
  276. package/dist/query/conditions/index.js +24 -0
  277. package/dist/query/conditions/index.js.map +1 -0
  278. package/dist/query/features/HasAlias.d.ts +6 -0
  279. package/dist/query/features/HasAlias.js +17 -0
  280. package/dist/query/features/HasAlias.js.map +1 -0
  281. package/dist/query/features/HasDistinct.d.ts +6 -0
  282. package/dist/query/features/HasDistinct.js +20 -0
  283. package/dist/query/features/HasDistinct.js.map +1 -0
  284. package/dist/query/features/HasFieldValues.d.ts +9 -0
  285. package/dist/query/features/HasFieldValues.js +27 -0
  286. package/dist/query/features/HasFieldValues.js.map +1 -0
  287. package/dist/query/features/HasGroupByFields.d.ts +7 -0
  288. package/dist/query/features/HasGroupByFields.js +21 -0
  289. package/dist/query/features/HasGroupByFields.js.map +1 -0
  290. package/dist/query/features/HasHavingConditions.d.ts +13 -0
  291. package/dist/query/features/HasHavingConditions.js +28 -0
  292. package/dist/query/features/HasHavingConditions.js.map +1 -0
  293. package/dist/query/features/HasJoins.d.ts +41 -0
  294. package/dist/query/features/HasJoins.js +66 -0
  295. package/dist/query/features/HasJoins.js.map +1 -0
  296. package/dist/query/features/HasLimit.d.ts +6 -0
  297. package/dist/query/features/HasLimit.js +20 -0
  298. package/dist/query/features/HasLimit.js.map +1 -0
  299. package/dist/query/features/HasOffset.d.ts +6 -0
  300. package/dist/query/features/HasOffset.js +20 -0
  301. package/dist/query/features/HasOffset.js.map +1 -0
  302. package/dist/query/features/HasOrderByFields.d.ts +15 -0
  303. package/dist/query/features/HasOrderByFields.js +38 -0
  304. package/dist/query/features/HasOrderByFields.js.map +1 -0
  305. package/dist/query/features/HasSelectFields.d.ts +11 -0
  306. package/dist/query/features/HasSelectFields.js +21 -0
  307. package/dist/query/features/HasSelectFields.js.map +1 -0
  308. package/dist/query/features/HasTable.d.ts +7 -0
  309. package/dist/query/features/HasTable.js +20 -0
  310. package/dist/query/features/HasTable.js.map +1 -0
  311. package/dist/query/features/HasUnions.d.ts +13 -0
  312. package/dist/query/features/HasUnions.js +21 -0
  313. package/dist/query/features/HasUnions.js.map +1 -0
  314. package/dist/query/features/HasWhen.d.ts +3 -0
  315. package/dist/query/features/HasWhen.js +13 -0
  316. package/dist/query/features/HasWhen.js.map +1 -0
  317. package/dist/query/features/HasWhereConditions.d.ts +35 -0
  318. package/dist/query/features/HasWhereConditions.js +92 -0
  319. package/dist/query/features/HasWhereConditions.js.map +1 -0
  320. package/dist/query/features/index.d.ts +14 -14
  321. package/dist/query/features/index.js +14 -14
  322. package/dist/query/features/index.js.map +1 -1
  323. package/dist/query/fields/BasicField.d.ts +5 -0
  324. package/dist/query/fields/BasicField.js +3 -0
  325. package/dist/query/fields/BasicField.js.map +1 -0
  326. package/dist/query/fields/Field.d.ts +3 -0
  327. package/dist/query/fields/Field.js +3 -0
  328. package/dist/query/fields/Field.js.map +1 -0
  329. package/dist/query/fields/RawField.d.ts +1 -0
  330. package/dist/query/fields/RawField.js +3 -0
  331. package/dist/query/fields/RawField.js.map +1 -0
  332. package/dist/query/fields/index.d.ts +3 -0
  333. package/dist/query/fields/index.js +20 -0
  334. package/dist/query/fields/index.js.map +1 -0
  335. package/dist/query/index.d.ts +7 -7
  336. package/dist/query/index.js +7 -7
  337. package/dist/query/index.js.map +1 -1
  338. package/dist/query/query.js +1 -1
  339. package/dist/query/query.js.map +1 -1
  340. package/dist/query/statement.js +1 -1
  341. package/dist/query/statement.js.map +1 -1
  342. package/dist/utilities.js +2 -3
  343. package/dist/utilities.js.map +1 -1
  344. package/package.json +21 -12
@@ -0,0 +1,524 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DefaultQueryBuilder = void 0;
4
+ const conditions_1 = require("../conditions");
5
+ const DeleteQuery_1 = require("../DeleteQuery");
6
+ const features_1 = require("../features");
7
+ const InsertQuery_1 = require("../InsertQuery");
8
+ const SelectQuery_1 = require("../SelectQuery");
9
+ const UpdateQuery_1 = require("../UpdateQuery");
10
+ const QueryBuilder_1 = require("./QueryBuilder");
11
+ class DefaultQueryBuilder extends QueryBuilder_1.QueryBuilder {
12
+ buildQuery(query) {
13
+ const statement = { sql: '', bindings: [] };
14
+ if (query instanceof SelectQuery_1.SelectQuery) {
15
+ this.buildSelectQuery(query, statement);
16
+ }
17
+ else if (query instanceof InsertQuery_1.InsertQuery) {
18
+ this.buildInsertQuery(query, statement);
19
+ }
20
+ else if (query instanceof UpdateQuery_1.UpdateQuery) {
21
+ this.buildUpdateQuery(query, statement);
22
+ }
23
+ else if (query instanceof DeleteQuery_1.DeleteQuery) {
24
+ this.buildDeleteQuery(query, statement);
25
+ }
26
+ return statement;
27
+ }
28
+ buildSelectQuery(query, statement) {
29
+ statement.sql += DefaultQueryBuilder.SELECT;
30
+ if (query.isDistinct()) {
31
+ statement.sql += DefaultQueryBuilder.SPACE;
32
+ statement.sql += DefaultQueryBuilder.DISTINCT;
33
+ }
34
+ statement.sql += DefaultQueryBuilder.SPACE;
35
+ const selectFields = query.getSelectFields();
36
+ if (selectFields && selectFields.length > 0) {
37
+ let isFirst = true;
38
+ for (const field of selectFields) {
39
+ if (!isFirst) {
40
+ statement.sql += DefaultQueryBuilder.COMMA;
41
+ statement.sql += DefaultQueryBuilder.SPACE;
42
+ }
43
+ this.buildSelectField(field, statement);
44
+ isFirst = false;
45
+ }
46
+ }
47
+ else {
48
+ statement.sql += DefaultQueryBuilder.ALL;
49
+ }
50
+ statement.sql += DefaultQueryBuilder.SPACE;
51
+ statement.sql += DefaultQueryBuilder.FROM;
52
+ statement.sql += DefaultQueryBuilder.SPACE;
53
+ this.buildTable(query.getTable(), statement);
54
+ const tableAlias = query.getAlias();
55
+ if (tableAlias != null) {
56
+ statement.sql += DefaultQueryBuilder.SPACE;
57
+ statement.sql += DefaultQueryBuilder.AS;
58
+ statement.sql += DefaultQueryBuilder.SPACE;
59
+ statement.sql += tableAlias;
60
+ }
61
+ const joins = query.getJoins();
62
+ if (joins != null && joins.length > 0) {
63
+ for (const join of joins) {
64
+ statement.sql += DefaultQueryBuilder.SPACE;
65
+ this.buildJoin(join, statement);
66
+ }
67
+ }
68
+ const whereConditions = query.getWhereConditions();
69
+ if (whereConditions && whereConditions.getConditions().length > 0) {
70
+ statement.sql += DefaultQueryBuilder.SPACE;
71
+ statement.sql += DefaultQueryBuilder.WHERE;
72
+ statement.sql += DefaultQueryBuilder.SPACE;
73
+ this.buildConditionGroup(whereConditions, statement);
74
+ }
75
+ const groupByFields = query.getGroupByFields();
76
+ if (groupByFields && groupByFields.length > 0) {
77
+ statement.sql += DefaultQueryBuilder.SPACE;
78
+ statement.sql += DefaultQueryBuilder.GROUP;
79
+ statement.sql += DefaultQueryBuilder.SPACE;
80
+ statement.sql += DefaultQueryBuilder.BY;
81
+ statement.sql += DefaultQueryBuilder.SPACE;
82
+ let isFirst = true;
83
+ for (const field of groupByFields) {
84
+ if (!isFirst) {
85
+ statement.sql += DefaultQueryBuilder.COMMA;
86
+ statement.sql += DefaultQueryBuilder.SPACE;
87
+ }
88
+ this.buildField(field, statement);
89
+ isFirst = false;
90
+ }
91
+ }
92
+ const havingConditions = query.getHavingConditions();
93
+ if (havingConditions && havingConditions.getConditions().length > 0) {
94
+ statement.sql += DefaultQueryBuilder.SPACE;
95
+ statement.sql += DefaultQueryBuilder.HAVING;
96
+ statement.sql += DefaultQueryBuilder.SPACE;
97
+ this.buildConditionGroup(havingConditions, statement);
98
+ }
99
+ const orderByFields = query.getOrderByFields();
100
+ if (orderByFields && orderByFields.length > 0) {
101
+ statement.sql += DefaultQueryBuilder.SPACE;
102
+ statement.sql += DefaultQueryBuilder.ORDER;
103
+ statement.sql += DefaultQueryBuilder.SPACE;
104
+ statement.sql += DefaultQueryBuilder.BY;
105
+ statement.sql += DefaultQueryBuilder.SPACE;
106
+ let isFirst = true;
107
+ for (const field of orderByFields) {
108
+ if (!isFirst) {
109
+ statement.sql += DefaultQueryBuilder.COMMA;
110
+ statement.sql += DefaultQueryBuilder.SPACE;
111
+ }
112
+ this.buildOrderByField(field, statement);
113
+ isFirst = false;
114
+ }
115
+ }
116
+ this.buildLimitOffset(query, statement);
117
+ for (const { query: unionQuery, all } of query.getUnions()) {
118
+ statement.sql += DefaultQueryBuilder.SPACE;
119
+ statement.sql += DefaultQueryBuilder.UNION;
120
+ if (all) {
121
+ statement.sql += DefaultQueryBuilder.SPACE;
122
+ statement.sql += 'ALL';
123
+ }
124
+ statement.sql += DefaultQueryBuilder.SPACE;
125
+ this.buildSelectQuery(unionQuery, statement);
126
+ }
127
+ }
128
+ buildLimitOffset(query, statement) {
129
+ if (query.getLimit() >= 0) {
130
+ statement.sql += DefaultQueryBuilder.SPACE;
131
+ statement.sql += DefaultQueryBuilder.LIMIT;
132
+ statement.sql += DefaultQueryBuilder.SPACE;
133
+ statement.sql += query.getLimit();
134
+ }
135
+ if (query.getOffset() >= 0) {
136
+ statement.sql += DefaultQueryBuilder.SPACE;
137
+ statement.sql += DefaultQueryBuilder.OFFSET;
138
+ statement.sql += DefaultQueryBuilder.SPACE;
139
+ statement.sql += query.getOffset();
140
+ }
141
+ }
142
+ buildInsertQuery(query, statement) {
143
+ statement.sql += DefaultQueryBuilder.INSERT;
144
+ statement.sql += DefaultQueryBuilder.SPACE;
145
+ statement.sql += DefaultQueryBuilder.INTO;
146
+ statement.sql += DefaultQueryBuilder.SPACE;
147
+ this.buildTable(query.getTable(), statement);
148
+ statement.sql += DefaultQueryBuilder.SPACE;
149
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
150
+ const fields = query.getFields();
151
+ let isFirst = true;
152
+ for (const fieldName in fields) {
153
+ if (!isFirst) {
154
+ statement.sql += DefaultQueryBuilder.COMMA;
155
+ statement.sql += DefaultQueryBuilder.SPACE;
156
+ }
157
+ statement.sql += fieldName;
158
+ isFirst = false;
159
+ }
160
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
161
+ statement.sql += DefaultQueryBuilder.SPACE;
162
+ statement.sql += DefaultQueryBuilder.VALUES;
163
+ statement.sql += DefaultQueryBuilder.SPACE;
164
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
165
+ isFirst = true;
166
+ for (const field in fields) {
167
+ const fieldValue = fields[field];
168
+ if (!isFirst) {
169
+ statement.sql += DefaultQueryBuilder.COMMA;
170
+ statement.sql += DefaultQueryBuilder.SPACE;
171
+ }
172
+ this.buildValue(fieldValue, statement);
173
+ isFirst = false;
174
+ }
175
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
176
+ }
177
+ buildUpdateQuery(query, statement) {
178
+ statement.sql += DefaultQueryBuilder.UPDATE;
179
+ statement.sql += DefaultQueryBuilder.SPACE;
180
+ this.buildTable(query.getTable(), statement);
181
+ statement.sql += DefaultQueryBuilder.SPACE;
182
+ statement.sql += DefaultQueryBuilder.SET;
183
+ statement.sql += DefaultQueryBuilder.SPACE;
184
+ const fields = query.getFields();
185
+ let isFirst = true;
186
+ for (const fieldName in fields) {
187
+ if (!isFirst) {
188
+ statement.sql += DefaultQueryBuilder.COMMA;
189
+ statement.sql += DefaultQueryBuilder.SPACE;
190
+ }
191
+ statement.sql += fieldName;
192
+ statement.sql += DefaultQueryBuilder.SPACE;
193
+ statement.sql += DefaultQueryBuilder.EQUALS;
194
+ statement.sql += DefaultQueryBuilder.SPACE;
195
+ this.buildValue(fields[fieldName], statement);
196
+ isFirst = false;
197
+ }
198
+ const whereConditions = query.getWhereConditions();
199
+ if (whereConditions && whereConditions.getConditions().length > 0) {
200
+ statement.sql += DefaultQueryBuilder.SPACE;
201
+ statement.sql += DefaultQueryBuilder.WHERE;
202
+ statement.sql += DefaultQueryBuilder.SPACE;
203
+ this.buildConditionGroup(whereConditions, statement);
204
+ }
205
+ }
206
+ buildDeleteQuery(query, statement) {
207
+ statement.sql += DefaultQueryBuilder.DELETE;
208
+ statement.sql += DefaultQueryBuilder.SPACE;
209
+ statement.sql += DefaultQueryBuilder.FROM;
210
+ statement.sql += DefaultQueryBuilder.SPACE;
211
+ this.buildTable(query.getTable(), statement);
212
+ const whereConditions = query.getWhereConditions();
213
+ if (whereConditions && whereConditions.getConditions().length > 0) {
214
+ statement.sql += DefaultQueryBuilder.SPACE;
215
+ statement.sql += DefaultQueryBuilder.WHERE;
216
+ statement.sql += DefaultQueryBuilder.SPACE;
217
+ this.buildConditionGroup(whereConditions, statement);
218
+ }
219
+ }
220
+ /**
221
+ * Outputs a plain identifier (column name). Override in engine-specific
222
+ * subclasses to add quoting (e.g. backticks for MySQL).
223
+ */
224
+ buildFieldName(name, statement) {
225
+ statement.sql += name;
226
+ }
227
+ /**
228
+ * Parses and outputs a raw string field, supporting:
229
+ * - 'field' → plain identifier
230
+ * - 'table.field' → quoted table + field (engine-aware)
231
+ * - 'FUNC(field)' → function call, field parsed recursively
232
+ * - 'FUNC(table.field)' → function call with qualified field
233
+ * - Any string with spaces is treated as a raw SQL expression and
234
+ * passed through as-is (e.g. 'COUNT(*) AS total').
235
+ */
236
+ buildRawFieldString(raw, statement) {
237
+ if (raw.includes(' ')) {
238
+ statement.sql += raw;
239
+ return;
240
+ }
241
+ const funcMatch = raw.match(/^(\w+)\((.+)\)$/);
242
+ if (funcMatch) {
243
+ statement.sql += funcMatch[1].toUpperCase();
244
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
245
+ this.buildRawFieldString(funcMatch[2].trim(), statement);
246
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
247
+ return;
248
+ }
249
+ if (raw === DefaultQueryBuilder.ALL) {
250
+ statement.sql += DefaultQueryBuilder.ALL;
251
+ return;
252
+ }
253
+ const dotIndex = raw.indexOf('.');
254
+ if (dotIndex !== -1) {
255
+ this.buildTable(raw.substring(0, dotIndex), statement);
256
+ statement.sql += DefaultQueryBuilder.POINT;
257
+ this.buildFieldName(raw.substring(dotIndex + 1), statement);
258
+ return;
259
+ }
260
+ this.buildFieldName(raw, statement);
261
+ }
262
+ buildSelectField(field, statement) {
263
+ if (typeof field === 'string' || field instanceof String) {
264
+ this.buildRawFieldString(field, statement);
265
+ }
266
+ else {
267
+ if (field.function) {
268
+ statement.sql += field.function.toUpperCase();
269
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
270
+ }
271
+ if (field.table) {
272
+ this.buildTable(field.table, statement);
273
+ statement.sql += DefaultQueryBuilder.POINT;
274
+ }
275
+ this.buildFieldName(field.name, statement);
276
+ if (field.function) {
277
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
278
+ }
279
+ if (field.alias) {
280
+ statement.sql += DefaultQueryBuilder.SPACE;
281
+ statement.sql += DefaultQueryBuilder.AS;
282
+ statement.sql += DefaultQueryBuilder.SPACE;
283
+ statement.sql += field.alias;
284
+ }
285
+ }
286
+ }
287
+ buildOrderByField(field, statement) {
288
+ if (typeof field === 'string' || field instanceof String) {
289
+ this.buildRawFieldString(field, statement);
290
+ }
291
+ else if (field instanceof Array) {
292
+ const [fieldName, direction] = field;
293
+ statement.sql += fieldName;
294
+ statement.sql += DefaultQueryBuilder.SPACE;
295
+ statement.sql += direction;
296
+ }
297
+ else {
298
+ if (field.table) {
299
+ this.buildTable(field.table, statement);
300
+ statement.sql += DefaultQueryBuilder.POINT;
301
+ }
302
+ this.buildFieldName(field.name, statement);
303
+ if (field.direction) {
304
+ statement.sql += DefaultQueryBuilder.SPACE;
305
+ statement.sql += field.direction;
306
+ }
307
+ }
308
+ }
309
+ buildField(field, statement) {
310
+ if (typeof field === 'string' || field instanceof String) {
311
+ this.buildRawFieldString(field, statement);
312
+ }
313
+ else {
314
+ if (field.table) {
315
+ this.buildTable(field.table, statement);
316
+ statement.sql += DefaultQueryBuilder.POINT;
317
+ }
318
+ this.buildFieldName(field.name, statement);
319
+ }
320
+ }
321
+ buildCondition(condition, statement) {
322
+ if (typeof condition === 'string' || condition instanceof String) {
323
+ statement.sql += condition;
324
+ }
325
+ else if (condition instanceof conditions_1.ConditionGroup) {
326
+ this.buildConditionGroup(condition, statement);
327
+ }
328
+ else if ('sql' in condition) {
329
+ const { sql, bindings } = condition;
330
+ statement.sql = sql;
331
+ statement.bindings.push(...bindings);
332
+ }
333
+ else if ('column' in condition) {
334
+ const { field, operator, column } = condition;
335
+ this.buildField(field, statement);
336
+ statement.sql += DefaultQueryBuilder.SPACE;
337
+ this.buildOperator(operator, statement);
338
+ statement.sql += DefaultQueryBuilder.SPACE;
339
+ this.buildField(column, statement);
340
+ }
341
+ else if ('field' in condition) {
342
+ const { field, operator, value } = condition;
343
+ this.buildField(field, statement);
344
+ statement.sql += DefaultQueryBuilder.SPACE;
345
+ if (value === null && (operator === '=' || operator === '!=' || operator === '<>')) {
346
+ statement.sql += DefaultQueryBuilder.IS;
347
+ statement.sql += DefaultQueryBuilder.SPACE;
348
+ if (operator !== '=') {
349
+ statement.sql += DefaultQueryBuilder.NOT;
350
+ statement.sql += DefaultQueryBuilder.SPACE;
351
+ }
352
+ statement.sql += DefaultQueryBuilder.NULL;
353
+ }
354
+ else if (operator && /^(NOT\s+)?BETWEEN$/i.test(operator) && Array.isArray(value) && value.length === 2) {
355
+ this.buildOperator(operator, statement);
356
+ statement.sql += DefaultQueryBuilder.SPACE;
357
+ this.buildSingleValue(value[0], statement);
358
+ statement.sql += DefaultQueryBuilder.SPACE;
359
+ statement.sql += DefaultQueryBuilder.AND;
360
+ statement.sql += DefaultQueryBuilder.SPACE;
361
+ this.buildSingleValue(value[1], statement);
362
+ }
363
+ else if (operator) {
364
+ this.buildOperator(operator, statement);
365
+ statement.sql += DefaultQueryBuilder.SPACE;
366
+ if (value != undefined) {
367
+ this.buildValue(value, statement);
368
+ }
369
+ }
370
+ }
371
+ }
372
+ buildConditionGroup(conditionGroup, statement) {
373
+ let isFirst = true;
374
+ for (const { connector, condition } of conditionGroup.getConditions()) {
375
+ if (!isFirst) {
376
+ statement.sql += DefaultQueryBuilder.SPACE;
377
+ statement.sql += connector == conditions_1.ConditionConnector.AND ? DefaultQueryBuilder.AND : DefaultQueryBuilder.OR;
378
+ statement.sql += DefaultQueryBuilder.SPACE;
379
+ }
380
+ if (condition instanceof conditions_1.ConditionGroup) {
381
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
382
+ this.buildConditionGroup(condition, statement);
383
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
384
+ }
385
+ else {
386
+ this.buildCondition(condition, statement);
387
+ }
388
+ isFirst = false;
389
+ }
390
+ }
391
+ buildJoin(join, statement) {
392
+ const { type, table, condition, alias } = join;
393
+ switch (type) {
394
+ case features_1.JoinType.INNER_JOIN:
395
+ statement.sql += DefaultQueryBuilder.INNER;
396
+ statement.sql += DefaultQueryBuilder.SPACE;
397
+ break;
398
+ case features_1.JoinType.OUTER_JOIN:
399
+ statement.sql += DefaultQueryBuilder.OUTER;
400
+ statement.sql += DefaultQueryBuilder.SPACE;
401
+ break;
402
+ case features_1.JoinType.LEFT_JOIN:
403
+ statement.sql += DefaultQueryBuilder.LEFT;
404
+ statement.sql += DefaultQueryBuilder.SPACE;
405
+ break;
406
+ case features_1.JoinType.RIGHT_JOIN:
407
+ statement.sql += DefaultQueryBuilder.RIGHT;
408
+ statement.sql += DefaultQueryBuilder.SPACE;
409
+ break;
410
+ case features_1.JoinType.CROSS_JOIN:
411
+ statement.sql += DefaultQueryBuilder.CROSS;
412
+ statement.sql += DefaultQueryBuilder.SPACE;
413
+ break;
414
+ }
415
+ statement.sql += DefaultQueryBuilder.JOIN;
416
+ statement.sql += DefaultQueryBuilder.SPACE;
417
+ this.buildTable(table, statement);
418
+ if (alias) {
419
+ statement.sql += DefaultQueryBuilder.SPACE;
420
+ statement.sql += DefaultQueryBuilder.AS;
421
+ statement.sql += DefaultQueryBuilder.SPACE;
422
+ statement.sql += alias;
423
+ }
424
+ statement.sql += DefaultQueryBuilder.SPACE;
425
+ statement.sql += DefaultQueryBuilder.ON;
426
+ statement.sql += DefaultQueryBuilder.SPACE;
427
+ this.buildConditionGroup(condition, statement);
428
+ }
429
+ buildTable(table, statement) {
430
+ if (typeof table === 'string' || table instanceof String) {
431
+ statement.sql += table;
432
+ }
433
+ else {
434
+ if (table.schema) {
435
+ statement.sql += table.schema;
436
+ statement.sql += DefaultQueryBuilder.POINT;
437
+ }
438
+ statement.sql += table.name;
439
+ }
440
+ }
441
+ buildValue(value, statement) {
442
+ if (value === null || value === undefined) {
443
+ this.buildSingleValue(value, statement);
444
+ }
445
+ else if (Array.isArray(value)) {
446
+ this.buildArrayValue(value, statement);
447
+ }
448
+ else if (value instanceof SelectQuery_1.SelectQuery) {
449
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
450
+ this.buildSelectQuery(value, statement);
451
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
452
+ }
453
+ else if (typeof value === 'object') {
454
+ this.buildField(value, statement);
455
+ }
456
+ else {
457
+ this.buildSingleValue(value, statement);
458
+ }
459
+ }
460
+ buildArrayValue(value, statement) {
461
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
462
+ let isFirst = true;
463
+ for (const valueItem of value) {
464
+ if (!isFirst) {
465
+ statement.sql += DefaultQueryBuilder.COMMA;
466
+ statement.sql += DefaultQueryBuilder.SPACE;
467
+ }
468
+ this.buildSingleValue(valueItem, statement);
469
+ isFirst = false;
470
+ }
471
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
472
+ }
473
+ buildSingleValue(value, statement) {
474
+ statement.sql += DefaultQueryBuilder.WILDCARD;
475
+ statement.bindings.push(value);
476
+ }
477
+ buildOperator(operator, statement) {
478
+ statement.sql += operator.toUpperCase();
479
+ }
480
+ }
481
+ exports.DefaultQueryBuilder = DefaultQueryBuilder;
482
+ DefaultQueryBuilder.SPACE = ' ';
483
+ DefaultQueryBuilder.COMMA = ',';
484
+ DefaultQueryBuilder.DOUBLE_QUOTES = '"';
485
+ DefaultQueryBuilder.EQUALS = '=';
486
+ DefaultQueryBuilder.PARENTHESIS_START = '(';
487
+ DefaultQueryBuilder.PARENTHESIS_END = ')';
488
+ DefaultQueryBuilder.SELECT = 'SELECT';
489
+ DefaultQueryBuilder.INSERT = 'INSERT';
490
+ DefaultQueryBuilder.UPDATE = 'UPDATE';
491
+ DefaultQueryBuilder.DELETE = 'DELETE';
492
+ DefaultQueryBuilder.INTO = 'INTO';
493
+ DefaultQueryBuilder.SET = 'SET';
494
+ DefaultQueryBuilder.VALUES = 'VALUES';
495
+ DefaultQueryBuilder.DISTINCT = 'DISTINCT';
496
+ DefaultQueryBuilder.ALL = '*';
497
+ DefaultQueryBuilder.AS = 'AS';
498
+ DefaultQueryBuilder.POINT = '.';
499
+ DefaultQueryBuilder.FROM = 'FROM';
500
+ DefaultQueryBuilder.AND = 'AND';
501
+ DefaultQueryBuilder.OR = 'OR';
502
+ DefaultQueryBuilder.NULL = 'NULL';
503
+ DefaultQueryBuilder.IS = 'IS';
504
+ DefaultQueryBuilder.NOT = 'NOT';
505
+ DefaultQueryBuilder.ON = 'ON';
506
+ DefaultQueryBuilder.WHERE = 'WHERE';
507
+ DefaultQueryBuilder.HAVING = 'HAVING';
508
+ DefaultQueryBuilder.GROUP = 'GROUP';
509
+ DefaultQueryBuilder.ORDER = 'ORDER';
510
+ DefaultQueryBuilder.BY = 'BY';
511
+ DefaultQueryBuilder.LIMIT = 'LIMIT';
512
+ DefaultQueryBuilder.OFFSET = 'OFFSET';
513
+ DefaultQueryBuilder.ASC = 'ASC';
514
+ DefaultQueryBuilder.DESC = 'DESC';
515
+ DefaultQueryBuilder.JOIN = 'JOIN';
516
+ DefaultQueryBuilder.INNER = 'INNER';
517
+ DefaultQueryBuilder.OUTER = 'OUTER';
518
+ DefaultQueryBuilder.LEFT = 'LEFT';
519
+ DefaultQueryBuilder.RIGHT = 'RIGHT';
520
+ DefaultQueryBuilder.CROSS = 'CROSS';
521
+ DefaultQueryBuilder.WILDCARD = '?';
522
+ DefaultQueryBuilder.UNION = 'UNION';
523
+ DefaultQueryBuilder.BETWEEN = 'BETWEEN';
524
+ //# sourceMappingURL=DefaultQueryBuilder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DefaultQueryBuilder.js","sourceRoot":"","sources":["../../../../src/database/query/builders/DefaultQueryBuilder.ts"],"names":[],"mappings":";;;AAAA,8CAA8F;AAC9F,gDAA4C;AAC5C,0CAAuE;AAEvE,gDAA4C;AAG5C,gDAA4C;AAE5C,gDAA4C;AAC5C,iDAA6C;AAE7C,MAAa,mBAAoB,SAAQ,2BAAY;IA4C5C,UAAU,CAAC,KAAY;QAC5B,MAAM,SAAS,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAA;QAE3C,IAAI,KAAK,YAAY,yBAAW,EAAE,CAAC;YACjC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACzC,CAAC;aAAM,IAAI,KAAK,YAAY,yBAAW,EAAE,CAAC;YACxC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACzC,CAAC;aAAM,IAAI,KAAK,YAAY,yBAAW,EAAE,CAAC;YACxC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACzC,CAAC;aAAM,IAAI,KAAK,YAAY,yBAAW,EAAE,CAAC;YACxC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACzC,CAAC;QAED,OAAO,SAAS,CAAA;IAClB,CAAC;IAES,gBAAgB,CAAC,KAAkB,EAAE,SAAoB;QACjE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;QAE3C,IAAI,KAAK,CAAC,UAAU,EAAE,EAAE,CAAC;YACvB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,QAAQ,CAAA;QAC/C,CAAC;QAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,MAAM,YAAY,GAAG,KAAK,CAAC,eAAe,EAAE,CAAA;QAE5C,IAAI,YAAY,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5C,IAAI,OAAO,GAAG,IAAI,CAAA;YAElB,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;gBACjC,IAAI,CAAC,OAAO,EAAE,CAAC;oBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;oBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC5C,CAAC;gBAED,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBACvC,OAAO,GAAG,KAAK,CAAA;YACjB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,GAAG,CAAA;QAC1C,CAAC;QAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAA;QACzC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,CAAA;QAE5C,MAAM,UAAU,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAA;QAEnC,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC;YACvB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,EAAE,CAAA;YACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,UAAU,CAAA;QAC7B,CAAC;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAA;QAE9B,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;YACjC,CAAC;QACH,CAAC;QAED,MAAM,eAAe,GAAG,KAAK,CAAC,kBAAkB,EAAE,CAAA;QAElD,IAAI,eAAe,IAAI,eAAe,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,mBAAmB,CAAC,eAAe,EAAE,SAAS,CAAC,CAAA;QACtD,CAAC;QAED,MAAM,aAAa,GAAG,KAAK,CAAC,gBAAgB,EAAE,CAAA;QAE9C,IAAI,aAAa,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,EAAE,CAAA;YACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,OAAO,GAAG,IAAI,CAAA;YAElB,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;gBAClC,IAAI,CAAC,OAAO,EAAE,CAAC;oBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;oBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC5C,CAAC;gBAED,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBACjC,OAAO,GAAG,KAAK,CAAA;YACjB,CAAC;QACH,CAAC;QAED,MAAM,gBAAgB,GAAG,KAAK,CAAC,mBAAmB,EAAE,CAAA;QAEpD,IAAI,gBAAgB,IAAI,gBAAgB,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;YAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,SAAS,CAAC,CAAA;QACvD,CAAC;QAED,MAAM,aAAa,GAAG,KAAK,CAAC,gBAAgB,EAAE,CAAA;QAE9C,IAAI,aAAa,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,EAAE,CAAA;YACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,OAAO,GAAG,IAAI,CAAA;YAElB,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;gBAClC,IAAI,CAAC,OAAO,EAAE,CAAC;oBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;oBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC5C,CAAC;gBAED,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBACxC,OAAO,GAAG,KAAK,CAAA;YACjB,CAAC;QACH,CAAC;QAED,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QAEvC,KAAK,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;YAC3D,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAE1C,IAAI,GAAG,EAAE,CAAC;gBACR,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAA;YACxB,CAAC;YAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAA;QAC9C,CAAC;IACH,CAAC;IAES,gBAAgB,CAAC,KAAkB,EAAE,SAAoB;QACjE,IAAI,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YAC1B,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAA;QACnC,CAAC;QAED,IAAI,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE,CAAC;YAC3B,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;YAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,SAAS,EAAE,CAAA;QACpC,CAAC;IACH,CAAC;IAES,gBAAgB,CAAC,KAAkB,EAAE,SAAoB;QACjE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;QAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAA;QACzC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,CAAA;QAC5C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,iBAAiB,CAAA;QACtD,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAA;QAChC,IAAI,OAAO,GAAG,IAAI,CAAA;QAElB,KAAK,MAAM,SAAS,IAAI,MAAM,EAAE,CAAC;YAC/B,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,SAAS,CAAC,GAAG,IAAI,SAAS,CAAA;YAC1B,OAAO,GAAG,KAAK,CAAA;QACjB,CAAC;QAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,eAAe,CAAA;QACpD,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;QAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,iBAAiB,CAAA;QACtD,OAAO,GAAG,IAAI,CAAA;QAEd,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;YAEhC,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,SAAS,CAAC,CAAA;YACtC,OAAO,GAAG,KAAK,CAAA;QACjB,CAAC;QAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,eAAe,CAAA;IACtD,CAAC;IAES,gBAAgB,CAAC,KAAkB,EAAE,SAAoB;QACjE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;QAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,CAAA;QAC5C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,GAAG,CAAA;QACxC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAA;QAChC,IAAI,OAAO,GAAG,IAAI,CAAA;QAElB,KAAK,MAAM,SAAS,IAAI,MAAM,EAAE,CAAC;YAC/B,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,SAAS,CAAC,GAAG,IAAI,SAAS,CAAA;YAC1B,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;YAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,SAAS,CAAC,CAAA;YAC7C,OAAO,GAAG,KAAK,CAAA;QACjB,CAAC;QAED,MAAM,eAAe,GAAG,KAAK,CAAC,kBAAkB,EAAE,CAAA;QAElD,IAAI,eAAe,IAAI,eAAe,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,mBAAmB,CAAC,eAAe,EAAE,SAAS,CAAC,CAAA;QACtD,CAAC;IACH,CAAC;IAES,gBAAgB,CAAC,KAAkB,EAAE,SAAoB;QACjE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAA;QAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAA;QACzC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,CAAA;QAC5C,MAAM,eAAe,GAAG,KAAK,CAAC,kBAAkB,EAAE,CAAA;QAElD,IAAI,eAAe,IAAI,eAAe,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClE,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,mBAAmB,CAAC,eAAe,EAAE,SAAS,CAAC,CAAA;QACtD,CAAC;IACH,CAAC;IAED;;;OAGG;IACO,cAAc,CAAC,IAAY,EAAE,SAAoB;QACzD,SAAS,CAAC,GAAG,IAAI,IAAI,CAAA;IACvB,CAAC;IAED;;;;;;;;OAQG;IACO,mBAAmB,CAAC,GAAW,EAAE,SAAoB;QAC7D,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACtB,SAAS,CAAC,GAAG,IAAI,GAAG,CAAA;YAEpB,OAAM;QACR,CAAC;QAED,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAA;QAE9C,IAAI,SAAS,EAAE,CAAC;YACd,SAAS,CAAC,GAAG,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA;YAC3C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,iBAAiB,CAAA;YACtD,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,SAAS,CAAC,CAAA;YACxD,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,eAAe,CAAA;YAEpD,OAAM;QACR,CAAC;QAED,IAAI,GAAG,KAAK,mBAAmB,CAAC,GAAG,EAAE,CAAC;YACpC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,GAAG,CAAA;YAExC,OAAM;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QAEjC,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAA;YACtD,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,SAAS,CAAC,CAAA;YAE3D,OAAM;QACR,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,SAAS,CAAC,CAAA;IACrC,CAAC;IAES,gBAAgB,CAAC,KAAkB,EAAE,SAAoB;QACjE,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;YACzD,IAAI,CAAC,mBAAmB,CAAC,KAAe,EAAE,SAAS,CAAC,CAAA;QACtD,CAAC;aAAM,CAAC;YACN,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACnB,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAA;gBAC7C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,iBAAiB,CAAA;YACxD,CAAC;YAED,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;YAE1C,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACnB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,eAAe,CAAA;YACtD,CAAC;YAED,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;gBAChB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,EAAE,CAAA;gBACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,KAAK,CAAA;YAC9B,CAAC;QACH,CAAC;IACH,CAAC;IAES,iBAAiB,CAAC,KAAmB,EAAE,SAAoB;QACnE,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;YACzD,IAAI,CAAC,mBAAmB,CAAC,KAAe,EAAE,SAAS,CAAC,CAAA;QACtD,CAAC;aAAM,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAClC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,GAAG,KAAK,CAAA;YAEpC,SAAS,CAAC,GAAG,IAAI,SAAS,CAAA;YAC1B,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,SAAS,CAAA;QAC5B,CAAC;aAAM,CAAC;YACN,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;YAE1C,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;gBACpB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,SAAS,CAAA;YAClC,CAAC;QACH,CAAC;IACH,CAAC;IAES,UAAU,CAAC,KAAY,EAAE,SAAoB;QACrD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;YACzD,IAAI,CAAC,mBAAmB,CAAC,KAAe,EAAE,SAAS,CAAC,CAAA;QACtD,CAAC;aAAM,CAAC;YACN,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;QAC5C,CAAC;IACH,CAAC;IAES,cAAc,CAAC,SAAoB,EAAE,SAAoB;QACjE,IAAI,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,YAAY,MAAM,EAAE,CAAC;YACjE,SAAS,CAAC,GAAG,IAAI,SAAS,CAAA;QAC5B,CAAC;aAAM,IAAI,SAAS,YAAY,2BAAc,EAAE,CAAC;YAC/C,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;QAChD,CAAC;aAAM,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;YAC9B,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,SAAS,CAAA;YAEnC,SAAS,CAAC,GAAG,GAAG,GAAG,CAAA;YACnB,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAA;QACtC,CAAC;aAAM,IAAI,QAAQ,IAAI,SAAS,EAAE,CAAC;YACjC,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,SAA4B,CAAA;YAEhE,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;YACjC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;YACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC,CAAA;QACpC,CAAC;aAAM,IAAI,OAAO,IAAI,SAAS,EAAE,CAAC;YAChC,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,SAAS,CAAA;YAE5C,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;YACjC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAE1C,IAAI,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,KAAK,IAAI,CAAC,EAAE,CAAC;gBACnF,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,EAAE,CAAA;gBACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAE1C,IAAI,QAAQ,KAAK,GAAG,EAAE,CAAC;oBACrB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,GAAG,CAAA;oBACxC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC5C,CAAC;gBAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAA;YAC3C,CAAC;iBAAM,IAAI,QAAQ,IAAI,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC1G,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;gBACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,GAAG,CAAA;gBACxC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAA;YAC5C,CAAC;iBAAM,IAAI,QAAQ,EAAE,CAAC;gBACpB,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;gBACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAE1C,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;oBACvB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBACnC,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAES,mBAAmB,CAAC,cAA8B,EAAE,SAAoB;QAChF,IAAI,OAAO,GAAG,IAAI,CAAA;QAElB,KAAK,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,cAAc,CAAC,aAAa,EAAE,EAAE,CAAC;YACtE,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,SAAS,IAAI,+BAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC,mBAAmB,CAAC,EAAE,CAAA;gBACvG,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,IAAI,SAAS,YAAY,2BAAc,EAAE,CAAC;gBACxC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,iBAAiB,CAAA;gBACtD,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;gBAC9C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,eAAe,CAAA;YACtD,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;YAC3C,CAAC;YAED,OAAO,GAAG,KAAK,CAAA;QACjB,CAAC;IACH,CAAC;IAES,SAAS,CAAC,IAAU,EAAE,SAAoB;QAClD,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,IAAI,CAAA;QAE9C,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,mBAAQ,CAAC,UAAU;gBACtB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,MAAK;YACP,KAAK,mBAAQ,CAAC,UAAU;gBACtB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,MAAK;YACP,KAAK,mBAAQ,CAAC,SAAS;gBACrB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAA;gBACzC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,MAAK;YACP,KAAK,mBAAQ,CAAC,UAAU;gBACtB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,MAAK;YACP,KAAK,mBAAQ,CAAC,UAAU;gBACtB,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,MAAK;QACT,CAAC;QAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAA;QACzC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QAEjC,IAAI,KAAK,EAAE,CAAC;YACV,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,EAAE,CAAA;YACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAA;QACxB,CAAC;QAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,EAAE,CAAA;QACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;QAC1C,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;IAChD,CAAC;IAES,UAAU,CAAC,KAAiB,EAAE,SAAoB;QAC1D,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;YACzD,SAAS,CAAC,GAAG,IAAI,KAAK,CAAA;QACxB,CAAC;aAAM,CAAC;YACN,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjB,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,MAAM,CAAA;gBAC7B,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,IAAI,CAAA;QAC7B,CAAC;IACH,CAAC;IAES,UAAU,CAAC,KAAU,EAAE,SAAoB;QACnD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YAC1C,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACzC,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACxC,CAAC;aAAM,IAAI,KAAK,YAAY,yBAAW,EAAE,CAAC;YACxC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,iBAAiB,CAAA;YACtD,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;YACvC,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,eAAe,CAAA;QACtD,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YACrC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACzC,CAAC;IACH,CAAC;IAES,eAAe,CAAC,KAAiB,EAAE,SAAoB;QAC/D,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,iBAAiB,CAAA;QACtD,IAAI,OAAO,GAAG,IAAI,CAAA;QAElB,KAAK,MAAM,SAAS,IAAI,KAAK,EAAE,CAAC;YAC9B,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;gBAC1C,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,KAAK,CAAA;YAC5C,CAAC;YAED,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;YAC3C,OAAO,GAAG,KAAK,CAAA;QACjB,CAAC;QAED,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,eAAe,CAAA;IACtD,CAAC;IAES,gBAAgB,CAAC,KAAU,EAAE,SAAoB;QACzD,SAAS,CAAC,GAAG,IAAI,mBAAmB,CAAC,QAAQ,CAAA;QAC7C,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAChC,CAAC;IAES,aAAa,CAAC,QAAgB,EAAE,SAAoB;QAC5D,SAAS,CAAC,GAAG,IAAI,QAAQ,CAAC,WAAW,EAAE,CAAA;IACzC,CAAC;;AA1kBH,kDA2kBC;AA1kB2B,yBAAK,GAAG,GAAG,CAAA;AACX,yBAAK,GAAG,GAAG,CAAA;AACX,iCAAa,GAAG,GAAG,CAAA;AACnB,0BAAM,GAAG,GAAG,CAAA;AACZ,qCAAiB,GAAG,GAAG,CAAA;AACvB,mCAAe,GAAG,GAAG,CAAA;AACrB,0BAAM,GAAG,QAAQ,CAAA;AACjB,0BAAM,GAAG,QAAQ,CAAA;AACjB,0BAAM,GAAG,QAAQ,CAAA;AACjB,0BAAM,GAAG,QAAQ,CAAA;AACjB,wBAAI,GAAG,MAAM,CAAA;AACb,uBAAG,GAAG,KAAK,CAAA;AACX,0BAAM,GAAG,QAAQ,CAAA;AACjB,4BAAQ,GAAG,UAAU,CAAA;AACrB,uBAAG,GAAG,GAAG,CAAA;AACT,sBAAE,GAAG,IAAI,CAAA;AACT,yBAAK,GAAG,GAAG,CAAA;AACX,wBAAI,GAAG,MAAM,CAAA;AACb,uBAAG,GAAG,KAAK,CAAA;AACX,sBAAE,GAAG,IAAI,CAAA;AACT,wBAAI,GAAG,MAAM,CAAA;AACb,sBAAE,GAAG,IAAI,CAAA;AACT,uBAAG,GAAG,KAAK,CAAA;AACX,sBAAE,GAAG,IAAI,CAAA;AACT,yBAAK,GAAG,OAAO,CAAA;AACf,0BAAM,GAAG,QAAQ,CAAA;AACjB,yBAAK,GAAG,OAAO,CAAA;AACf,yBAAK,GAAG,OAAO,CAAA;AACf,sBAAE,GAAG,IAAI,CAAA;AACT,yBAAK,GAAG,OAAO,CAAA;AACf,0BAAM,GAAG,QAAQ,CAAA;AACjB,uBAAG,GAAG,KAAK,CAAA;AACX,wBAAI,GAAG,MAAM,CAAA;AACb,wBAAI,GAAG,MAAM,CAAA;AACb,yBAAK,GAAG,OAAO,CAAA;AACf,yBAAK,GAAG,OAAO,CAAA;AACf,wBAAI,GAAG,MAAM,CAAA;AACb,yBAAK,GAAG,OAAO,CAAA;AACf,yBAAK,GAAG,OAAO,CAAA;AACf,4BAAQ,GAAG,GAAG,CAAA;AACd,yBAAK,GAAG,OAAO,CAAA;AACf,2BAAO,GAAG,SAAS,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { Query } from '../Query';
2
+ import { Statement } from '../Statement';
3
+ export declare abstract class QueryBuilder {
4
+ abstract buildQuery(query: Query): Statement;
5
+ }
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.QueryBuilder = void 0;
4
+ class QueryBuilder {
5
+ }
6
+ exports.QueryBuilder = QueryBuilder;
7
+ //# sourceMappingURL=QueryBuilder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryBuilder.js","sourceRoot":"","sources":["../../../../src/database/query/builders/QueryBuilder.ts"],"names":[],"mappings":";;;AAGA,MAAsB,YAAY;CAEjC;AAFD,oCAEC"}
@@ -0,0 +1,2 @@
1
+ export * from './DefaultQueryBuilder';
2
+ export * from './QueryBuilder';
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./DefaultQueryBuilder"), exports);
18
+ __exportStar(require("./QueryBuilder"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/query/builders/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAqC;AACrC,iDAA8B"}
@@ -0,0 +1,6 @@
1
+ import { Field } from '../fields';
2
+ export type BasicCondition = {
3
+ field: Field;
4
+ operator?: string;
5
+ value: any;
6
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=BasicCondition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BasicCondition.js","sourceRoot":"","sources":["../../../../src/database/query/conditions/BasicCondition.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ import { Field } from '../fields';
2
+ export type ColumnCondition = {
3
+ field: Field;
4
+ operator: string;
5
+ column: Field;
6
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=ColumnCondition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColumnCondition.js","sourceRoot":"","sources":["../../../../src/database/query/conditions/ColumnCondition.ts"],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ import { BasicCondition } from './BasicCondition';
2
+ import { ColumnCondition } from './ColumnCondition';
3
+ import { ConditionGroup } from './ConditionGroup';
4
+ import { RawCondition } from './RawCondition';
5
+ export type Condition = RawCondition | BasicCondition | ColumnCondition | ConditionGroup | ((group: ConditionGroup) => void);
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=Condition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Condition.js","sourceRoot":"","sources":["../../../../src/database/query/conditions/Condition.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ export declare enum ConditionConnector {
2
+ AND = 0,
3
+ OR = 1
4
+ }