@revealui/db 0.2.0

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 (191) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +137 -0
  3. package/dist/audit-store.d.ts +56 -0
  4. package/dist/audit-store.d.ts.map +1 -0
  5. package/dist/audit-store.js +120 -0
  6. package/dist/audit-store.js.map +1 -0
  7. package/dist/client/index.d.ts +214 -0
  8. package/dist/client/index.d.ts.map +1 -0
  9. package/dist/client/index.js +396 -0
  10. package/dist/client/index.js.map +1 -0
  11. package/dist/client/types.d.ts +109 -0
  12. package/dist/client/types.d.ts.map +1 -0
  13. package/dist/client/types.js +10 -0
  14. package/dist/client/types.js.map +1 -0
  15. package/dist/crypto.d.ts +27 -0
  16. package/dist/crypto.d.ts.map +1 -0
  17. package/dist/crypto.js +68 -0
  18. package/dist/crypto.js.map +1 -0
  19. package/dist/index.d.ts +29 -0
  20. package/dist/index.d.ts.map +1 -0
  21. package/dist/index.js +31 -0
  22. package/dist/index.js.map +1 -0
  23. package/dist/log-transport.d.ts +20 -0
  24. package/dist/log-transport.d.ts.map +1 -0
  25. package/dist/log-transport.js +49 -0
  26. package/dist/log-transport.js.map +1 -0
  27. package/dist/pool.d.ts +36 -0
  28. package/dist/pool.d.ts.map +1 -0
  29. package/dist/pool.js +218 -0
  30. package/dist/pool.js.map +1 -0
  31. package/dist/queries/boards.d.ts +138 -0
  32. package/dist/queries/boards.d.ts.map +1 -0
  33. package/dist/queries/boards.js +87 -0
  34. package/dist/queries/boards.js.map +1 -0
  35. package/dist/queries/code-provenance.d.ts +250 -0
  36. package/dist/queries/code-provenance.d.ts.map +1 -0
  37. package/dist/queries/code-provenance.js +130 -0
  38. package/dist/queries/code-provenance.js.map +1 -0
  39. package/dist/queries/optimized-queries.d.ts +89 -0
  40. package/dist/queries/optimized-queries.d.ts.map +1 -0
  41. package/dist/queries/optimized-queries.js +371 -0
  42. package/dist/queries/optimized-queries.js.map +1 -0
  43. package/dist/queries/ticket-comments.d.ts +37 -0
  44. package/dist/queries/ticket-comments.d.ts.map +1 -0
  45. package/dist/queries/ticket-comments.js +52 -0
  46. package/dist/queries/ticket-comments.js.map +1 -0
  47. package/dist/queries/ticket-labels.d.ts +69 -0
  48. package/dist/queries/ticket-labels.d.ts.map +1 -0
  49. package/dist/queries/ticket-labels.js +51 -0
  50. package/dist/queries/ticket-labels.js.map +1 -0
  51. package/dist/queries/tickets.d.ts +301 -0
  52. package/dist/queries/tickets.d.ts.map +1 -0
  53. package/dist/queries/tickets.js +89 -0
  54. package/dist/queries/tickets.js.map +1 -0
  55. package/dist/queries/todos.d.ts +37 -0
  56. package/dist/queries/todos.d.ts.map +1 -0
  57. package/dist/queries/todos.js +37 -0
  58. package/dist/queries/todos.js.map +1 -0
  59. package/dist/schema/agents.d.ts +1413 -0
  60. package/dist/schema/agents.d.ts.map +1 -0
  61. package/dist/schema/agents.js +207 -0
  62. package/dist/schema/agents.js.map +1 -0
  63. package/dist/schema/api-keys.d.ts +298 -0
  64. package/dist/schema/api-keys.d.ts.map +1 -0
  65. package/dist/schema/api-keys.js +53 -0
  66. package/dist/schema/api-keys.js.map +1 -0
  67. package/dist/schema/app-logs.d.ts +168 -0
  68. package/dist/schema/app-logs.d.ts.map +1 -0
  69. package/dist/schema/app-logs.js +25 -0
  70. package/dist/schema/app-logs.js.map +1 -0
  71. package/dist/schema/audit-log.d.ts +174 -0
  72. package/dist/schema/audit-log.d.ts.map +1 -0
  73. package/dist/schema/audit-log.js +37 -0
  74. package/dist/schema/audit-log.js.map +1 -0
  75. package/dist/schema/cms.d.ts +1015 -0
  76. package/dist/schema/cms.d.ts.map +1 -0
  77. package/dist/schema/cms.js +137 -0
  78. package/dist/schema/cms.js.map +1 -0
  79. package/dist/schema/code-provenance.d.ts +488 -0
  80. package/dist/schema/code-provenance.d.ts.map +1 -0
  81. package/dist/schema/code-provenance.js +72 -0
  82. package/dist/schema/code-provenance.js.map +1 -0
  83. package/dist/schema/collab-edits.d.ts +165 -0
  84. package/dist/schema/collab-edits.d.ts.map +1 -0
  85. package/dist/schema/collab-edits.js +21 -0
  86. package/dist/schema/collab-edits.js.map +1 -0
  87. package/dist/schema/crdt-operations.d.ts +153 -0
  88. package/dist/schema/crdt-operations.d.ts.map +1 -0
  89. package/dist/schema/crdt-operations.js +30 -0
  90. package/dist/schema/crdt-operations.js.map +1 -0
  91. package/dist/schema/error-events.d.ts +223 -0
  92. package/dist/schema/error-events.d.ts.map +1 -0
  93. package/dist/schema/error-events.js +44 -0
  94. package/dist/schema/error-events.js.map +1 -0
  95. package/dist/schema/index.d.ts +130 -0
  96. package/dist/schema/index.d.ts.map +1 -0
  97. package/dist/schema/index.js +310 -0
  98. package/dist/schema/index.js.map +1 -0
  99. package/dist/schema/licenses.d.ts +189 -0
  100. package/dist/schema/licenses.d.ts.map +1 -0
  101. package/dist/schema/licenses.js +39 -0
  102. package/dist/schema/licenses.js.map +1 -0
  103. package/dist/schema/node-ids.d.ts +122 -0
  104. package/dist/schema/node-ids.d.ts.map +1 -0
  105. package/dist/schema/node-ids.js +25 -0
  106. package/dist/schema/node-ids.js.map +1 -0
  107. package/dist/schema/pages.d.ts +488 -0
  108. package/dist/schema/pages.d.ts.map +1 -0
  109. package/dist/schema/pages.js +70 -0
  110. package/dist/schema/pages.js.map +1 -0
  111. package/dist/schema/password-reset-tokens.d.ts +137 -0
  112. package/dist/schema/password-reset-tokens.d.ts.map +1 -0
  113. package/dist/schema/password-reset-tokens.js +26 -0
  114. package/dist/schema/password-reset-tokens.js.map +1 -0
  115. package/dist/schema/query.d.ts +11 -0
  116. package/dist/schema/query.d.ts.map +1 -0
  117. package/dist/schema/query.js +11 -0
  118. package/dist/schema/query.js.map +1 -0
  119. package/dist/schema/rate-limits.d.ts +212 -0
  120. package/dist/schema/rate-limits.d.ts.map +1 -0
  121. package/dist/schema/rate-limits.js +38 -0
  122. package/dist/schema/rate-limits.js.map +1 -0
  123. package/dist/schema/rest.d.ts +31 -0
  124. package/dist/schema/rest.d.ts.map +1 -0
  125. package/dist/schema/rest.js +37 -0
  126. package/dist/schema/rest.js.map +1 -0
  127. package/dist/schema/sites.d.ts +365 -0
  128. package/dist/schema/sites.d.ts.map +1 -0
  129. package/dist/schema/sites.js +62 -0
  130. package/dist/schema/sites.js.map +1 -0
  131. package/dist/schema/tickets.d.ts +1118 -0
  132. package/dist/schema/tickets.d.ts.map +1 -0
  133. package/dist/schema/tickets.js +150 -0
  134. package/dist/schema/tickets.js.map +1 -0
  135. package/dist/schema/todos.d.ts +98 -0
  136. package/dist/schema/todos.d.ts.map +1 -0
  137. package/dist/schema/todos.js +12 -0
  138. package/dist/schema/todos.js.map +1 -0
  139. package/dist/schema/users.d.ts +503 -0
  140. package/dist/schema/users.d.ts.map +1 -0
  141. package/dist/schema/users.js +75 -0
  142. package/dist/schema/users.js.map +1 -0
  143. package/dist/schema/vector.d.ts +9 -0
  144. package/dist/schema/vector.d.ts.map +1 -0
  145. package/dist/schema/vector.js +9 -0
  146. package/dist/schema/vector.js.map +1 -0
  147. package/dist/schema/waitlist.d.ts +151 -0
  148. package/dist/schema/waitlist.d.ts.map +1 -0
  149. package/dist/schema/waitlist.js +17 -0
  150. package/dist/schema/waitlist.js.map +1 -0
  151. package/dist/schema/yjs-documents.d.ts +116 -0
  152. package/dist/schema/yjs-documents.d.ts.map +1 -0
  153. package/dist/schema/yjs-documents.js +15 -0
  154. package/dist/schema/yjs-documents.js.map +1 -0
  155. package/dist/types/database.d.ts +740 -0
  156. package/dist/types/database.d.ts.map +1 -0
  157. package/dist/types/database.js +151 -0
  158. package/dist/types/database.js.map +1 -0
  159. package/dist/types/discover.d.ts +83 -0
  160. package/dist/types/discover.d.ts.map +1 -0
  161. package/dist/types/discover.js +271 -0
  162. package/dist/types/discover.js.map +1 -0
  163. package/dist/types/extract-relationships.d.ts +115 -0
  164. package/dist/types/extract-relationships.d.ts.map +1 -0
  165. package/dist/types/extract-relationships.js +455 -0
  166. package/dist/types/extract-relationships.js.map +1 -0
  167. package/dist/types/generate-contracts.d.ts +19 -0
  168. package/dist/types/generate-contracts.d.ts.map +1 -0
  169. package/dist/types/generate-contracts.js +128 -0
  170. package/dist/types/generate-contracts.js.map +1 -0
  171. package/dist/types/generate-zod-schemas.d.ts +20 -0
  172. package/dist/types/generate-zod-schemas.d.ts.map +1 -0
  173. package/dist/types/generate-zod-schemas.js +128 -0
  174. package/dist/types/generate-zod-schemas.js.map +1 -0
  175. package/dist/types/generate.d.ts +17 -0
  176. package/dist/types/generate.d.ts.map +1 -0
  177. package/dist/types/generate.js +298 -0
  178. package/dist/types/generate.js.map +1 -0
  179. package/dist/types/index.d.ts +19 -0
  180. package/dist/types/index.d.ts.map +1 -0
  181. package/dist/types/index.js +19 -0
  182. package/dist/types/index.js.map +1 -0
  183. package/dist/types/introspect.d.ts +75 -0
  184. package/dist/types/introspect.d.ts.map +1 -0
  185. package/dist/types/introspect.js +187 -0
  186. package/dist/types/introspect.js.map +1 -0
  187. package/dist/types/stripe-schema.d.ts +893 -0
  188. package/dist/types/stripe-schema.d.ts.map +1 -0
  189. package/dist/types/stripe-schema.js +112 -0
  190. package/dist/types/stripe-schema.js.map +1 -0
  191. package/package.json +154 -0
@@ -0,0 +1,301 @@
1
+ /**
2
+ * Ticket database queries
3
+ */
4
+ import type { DatabaseClient } from '../client/types.js';
5
+ export declare function getTicketsByBoard(db: DatabaseClient, boardId: string, filters?: {
6
+ status?: string;
7
+ priority?: string;
8
+ type?: string;
9
+ assigneeId?: string;
10
+ columnId?: string;
11
+ }): Promise<{
12
+ id: string;
13
+ schemaVersion: string;
14
+ boardId: string;
15
+ columnId: string | null;
16
+ parentTicketId: string | null;
17
+ ticketNumber: number;
18
+ title: string;
19
+ description: unknown;
20
+ status: string;
21
+ priority: string;
22
+ type: string;
23
+ assigneeId: string | null;
24
+ reporterId: string | null;
25
+ dueDate: Date | null;
26
+ estimatedEffort: number | null;
27
+ sortOrder: number;
28
+ commentCount: number;
29
+ attachments: {
30
+ url: string;
31
+ filename: string;
32
+ mimeType: string;
33
+ filesize: number;
34
+ }[];
35
+ metadata: unknown;
36
+ closedAt: Date | null;
37
+ createdAt: Date;
38
+ updatedAt: Date;
39
+ }[]>;
40
+ export declare function getTicketById(db: DatabaseClient, id: string): Promise<{
41
+ id: string;
42
+ schemaVersion: string;
43
+ boardId: string;
44
+ columnId: string | null;
45
+ parentTicketId: string | null;
46
+ ticketNumber: number;
47
+ title: string;
48
+ description: unknown;
49
+ status: string;
50
+ priority: string;
51
+ type: string;
52
+ assigneeId: string | null;
53
+ reporterId: string | null;
54
+ dueDate: Date | null;
55
+ estimatedEffort: number | null;
56
+ sortOrder: number;
57
+ commentCount: number;
58
+ attachments: {
59
+ url: string;
60
+ filename: string;
61
+ mimeType: string;
62
+ filesize: number;
63
+ }[];
64
+ metadata: unknown;
65
+ closedAt: Date | null;
66
+ createdAt: Date;
67
+ updatedAt: Date;
68
+ } | null>;
69
+ export declare function getTicketByNumber(db: DatabaseClient, boardId: string, ticketNumber: number): Promise<{
70
+ id: string;
71
+ schemaVersion: string;
72
+ boardId: string;
73
+ columnId: string | null;
74
+ parentTicketId: string | null;
75
+ ticketNumber: number;
76
+ title: string;
77
+ description: unknown;
78
+ status: string;
79
+ priority: string;
80
+ type: string;
81
+ assigneeId: string | null;
82
+ reporterId: string | null;
83
+ dueDate: Date | null;
84
+ estimatedEffort: number | null;
85
+ sortOrder: number;
86
+ commentCount: number;
87
+ attachments: {
88
+ url: string;
89
+ filename: string;
90
+ mimeType: string;
91
+ filesize: number;
92
+ }[];
93
+ metadata: unknown;
94
+ closedAt: Date | null;
95
+ createdAt: Date;
96
+ updatedAt: Date;
97
+ } | null>;
98
+ export declare function createTicket(db: DatabaseClient, data: {
99
+ id: string;
100
+ boardId: string;
101
+ columnId?: string;
102
+ parentTicketId?: string;
103
+ title: string;
104
+ description?: unknown;
105
+ status?: string;
106
+ priority?: string;
107
+ type?: string;
108
+ assigneeId?: string;
109
+ reporterId?: string;
110
+ dueDate?: Date;
111
+ estimatedEffort?: number;
112
+ }): Promise<{
113
+ id: string;
114
+ schemaVersion: string;
115
+ type: string;
116
+ status: string;
117
+ createdAt: Date;
118
+ updatedAt: Date;
119
+ description: unknown;
120
+ priority: string;
121
+ metadata: unknown;
122
+ title: string;
123
+ boardId: string;
124
+ columnId: string | null;
125
+ parentTicketId: string | null;
126
+ ticketNumber: number;
127
+ assigneeId: string | null;
128
+ reporterId: string | null;
129
+ dueDate: Date | null;
130
+ estimatedEffort: number | null;
131
+ sortOrder: number;
132
+ commentCount: number;
133
+ attachments: {
134
+ url: string;
135
+ filename: string;
136
+ mimeType: string;
137
+ filesize: number;
138
+ }[];
139
+ closedAt: Date | null;
140
+ } | undefined>;
141
+ export declare function updateTicket(db: DatabaseClient, id: string, data: Partial<{
142
+ title: string;
143
+ description: unknown;
144
+ status: string;
145
+ priority: string;
146
+ type: string;
147
+ assigneeId: string | null;
148
+ reporterId: string | null;
149
+ columnId: string | null;
150
+ dueDate: Date | null;
151
+ estimatedEffort: number | null;
152
+ sortOrder: number;
153
+ closedAt: Date | null;
154
+ metadata: Record<string, unknown>;
155
+ }>): Promise<{
156
+ id: string;
157
+ schemaVersion: string;
158
+ boardId: string;
159
+ columnId: string | null;
160
+ parentTicketId: string | null;
161
+ ticketNumber: number;
162
+ title: string;
163
+ description: unknown;
164
+ status: string;
165
+ priority: string;
166
+ type: string;
167
+ assigneeId: string | null;
168
+ reporterId: string | null;
169
+ dueDate: Date | null;
170
+ estimatedEffort: number | null;
171
+ sortOrder: number;
172
+ commentCount: number;
173
+ attachments: {
174
+ url: string;
175
+ filename: string;
176
+ mimeType: string;
177
+ filesize: number;
178
+ }[];
179
+ metadata: unknown;
180
+ closedAt: Date | null;
181
+ createdAt: Date;
182
+ updatedAt: Date;
183
+ } | null>;
184
+ export declare function deleteTicket(db: DatabaseClient, id: string): Promise<void>;
185
+ export declare function moveTicket(db: DatabaseClient, id: string, columnId: string, sortOrder: number): Promise<{
186
+ id: string;
187
+ schemaVersion: string;
188
+ boardId: string;
189
+ columnId: string | null;
190
+ parentTicketId: string | null;
191
+ ticketNumber: number;
192
+ title: string;
193
+ description: unknown;
194
+ status: string;
195
+ priority: string;
196
+ type: string;
197
+ assigneeId: string | null;
198
+ reporterId: string | null;
199
+ dueDate: Date | null;
200
+ estimatedEffort: number | null;
201
+ sortOrder: number;
202
+ commentCount: number;
203
+ attachments: {
204
+ url: string;
205
+ filename: string;
206
+ mimeType: string;
207
+ filesize: number;
208
+ }[];
209
+ metadata: unknown;
210
+ closedAt: Date | null;
211
+ createdAt: Date;
212
+ updatedAt: Date;
213
+ } | null>;
214
+ export declare function getSubtickets(db: DatabaseClient, parentTicketId: string): Promise<{
215
+ id: string;
216
+ schemaVersion: string;
217
+ boardId: string;
218
+ columnId: string | null;
219
+ parentTicketId: string | null;
220
+ ticketNumber: number;
221
+ title: string;
222
+ description: unknown;
223
+ status: string;
224
+ priority: string;
225
+ type: string;
226
+ assigneeId: string | null;
227
+ reporterId: string | null;
228
+ dueDate: Date | null;
229
+ estimatedEffort: number | null;
230
+ sortOrder: number;
231
+ commentCount: number;
232
+ attachments: {
233
+ url: string;
234
+ filename: string;
235
+ mimeType: string;
236
+ filesize: number;
237
+ }[];
238
+ metadata: unknown;
239
+ closedAt: Date | null;
240
+ createdAt: Date;
241
+ updatedAt: Date;
242
+ }[]>;
243
+ export declare function getTicketsByColumn(db: DatabaseClient, columnId: string): Promise<{
244
+ id: string;
245
+ schemaVersion: string;
246
+ boardId: string;
247
+ columnId: string | null;
248
+ parentTicketId: string | null;
249
+ ticketNumber: number;
250
+ title: string;
251
+ description: unknown;
252
+ status: string;
253
+ priority: string;
254
+ type: string;
255
+ assigneeId: string | null;
256
+ reporterId: string | null;
257
+ dueDate: Date | null;
258
+ estimatedEffort: number | null;
259
+ sortOrder: number;
260
+ commentCount: number;
261
+ attachments: {
262
+ url: string;
263
+ filename: string;
264
+ mimeType: string;
265
+ filesize: number;
266
+ }[];
267
+ metadata: unknown;
268
+ closedAt: Date | null;
269
+ createdAt: Date;
270
+ updatedAt: Date;
271
+ }[]>;
272
+ export declare function getOverdueTickets(db: DatabaseClient, boardId: string): Promise<{
273
+ id: string;
274
+ schemaVersion: string;
275
+ boardId: string;
276
+ columnId: string | null;
277
+ parentTicketId: string | null;
278
+ ticketNumber: number;
279
+ title: string;
280
+ description: unknown;
281
+ status: string;
282
+ priority: string;
283
+ type: string;
284
+ assigneeId: string | null;
285
+ reporterId: string | null;
286
+ dueDate: Date | null;
287
+ estimatedEffort: number | null;
288
+ sortOrder: number;
289
+ commentCount: number;
290
+ attachments: {
291
+ url: string;
292
+ filename: string;
293
+ mimeType: string;
294
+ filesize: number;
295
+ }[];
296
+ metadata: unknown;
297
+ closedAt: Date | null;
298
+ createdAt: Date;
299
+ updatedAt: Date;
300
+ }[]>;
301
+ //# sourceMappingURL=tickets.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tickets.d.ts","sourceRoot":"","sources":["../../src/queries/tickets.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,89 @@
1
+ /**
2
+ * Ticket database queries
3
+ */
4
+ import { and, desc, eq, sql } from 'drizzle-orm';
5
+ import { tickets } from '../schema/tickets.js';
6
+ export async function getTicketsByBoard(db, boardId, filters) {
7
+ const conditions = [eq(tickets.boardId, boardId)];
8
+ if (filters?.status)
9
+ conditions.push(eq(tickets.status, filters.status));
10
+ if (filters?.priority)
11
+ conditions.push(eq(tickets.priority, filters.priority));
12
+ if (filters?.type)
13
+ conditions.push(eq(tickets.type, filters.type));
14
+ if (filters?.assigneeId)
15
+ conditions.push(eq(tickets.assigneeId, filters.assigneeId));
16
+ if (filters?.columnId)
17
+ conditions.push(eq(tickets.columnId, filters.columnId));
18
+ return db
19
+ .select()
20
+ .from(tickets)
21
+ .where(and(...conditions))
22
+ .orderBy(tickets.sortOrder);
23
+ }
24
+ export async function getTicketById(db, id) {
25
+ const result = await db.select().from(tickets).where(eq(tickets.id, id)).limit(1);
26
+ return result[0] ?? null;
27
+ }
28
+ export async function getTicketByNumber(db, boardId, ticketNumber) {
29
+ const result = await db
30
+ .select()
31
+ .from(tickets)
32
+ .where(and(eq(tickets.boardId, boardId), eq(tickets.ticketNumber, ticketNumber)))
33
+ .limit(1);
34
+ return result[0] ?? null;
35
+ }
36
+ export async function createTicket(db, data) {
37
+ // Auto-increment ticket number per board
38
+ const maxResult = await db
39
+ .select({ max: sql `COALESCE(MAX(${tickets.ticketNumber}), 0)` })
40
+ .from(tickets)
41
+ .where(eq(tickets.boardId, data.boardId));
42
+ const nextNumber = (maxResult[0]?.max ?? 0) + 1;
43
+ const result = await db
44
+ .insert(tickets)
45
+ .values({
46
+ ...data,
47
+ ticketNumber: nextNumber,
48
+ description: data.description ?? null,
49
+ })
50
+ .returning();
51
+ return result[0];
52
+ }
53
+ export async function updateTicket(db, id, data) {
54
+ const result = await db
55
+ .update(tickets)
56
+ .set({ ...data, updatedAt: new Date() })
57
+ .where(eq(tickets.id, id))
58
+ .returning();
59
+ return result[0] ?? null;
60
+ }
61
+ export async function deleteTicket(db, id) {
62
+ await db.delete(tickets).where(eq(tickets.id, id));
63
+ }
64
+ export async function moveTicket(db, id, columnId, sortOrder) {
65
+ const result = await db
66
+ .update(tickets)
67
+ .set({ columnId, sortOrder, updatedAt: new Date() })
68
+ .where(eq(tickets.id, id))
69
+ .returning();
70
+ return result[0] ?? null;
71
+ }
72
+ export async function getSubtickets(db, parentTicketId) {
73
+ return db
74
+ .select()
75
+ .from(tickets)
76
+ .where(eq(tickets.parentTicketId, parentTicketId))
77
+ .orderBy(tickets.sortOrder);
78
+ }
79
+ export async function getTicketsByColumn(db, columnId) {
80
+ return db.select().from(tickets).where(eq(tickets.columnId, columnId)).orderBy(tickets.sortOrder);
81
+ }
82
+ export async function getOverdueTickets(db, boardId) {
83
+ return db
84
+ .select()
85
+ .from(tickets)
86
+ .where(and(eq(tickets.boardId, boardId), sql `${tickets.dueDate} < NOW()`, sql `${tickets.status} NOT IN ('done', 'closed')`))
87
+ .orderBy(desc(tickets.dueDate));
88
+ }
89
+ //# sourceMappingURL=tickets.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tickets.js","sourceRoot":"","sources":["../../src/queries/tickets.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Todo database queries
3
+ */
4
+ import type { DatabaseClient } from '../client/types.js';
5
+ export declare function getAllTodos(db: DatabaseClient): Promise<{
6
+ id: string;
7
+ text: string;
8
+ completed: boolean;
9
+ createdAt: Date;
10
+ updatedAt: Date;
11
+ }[]>;
12
+ export declare function getTodoById(db: DatabaseClient, id: string): Promise<{
13
+ id: string;
14
+ text: string;
15
+ completed: boolean;
16
+ createdAt: Date;
17
+ updatedAt: Date;
18
+ } | null>;
19
+ export declare function createTodo(db: DatabaseClient, text: string): Promise<{
20
+ id: string;
21
+ createdAt: Date;
22
+ updatedAt: Date;
23
+ text: string;
24
+ completed: boolean;
25
+ } | undefined>;
26
+ export declare function updateTodo(db: DatabaseClient, id: string, data: {
27
+ text?: string;
28
+ completed?: boolean;
29
+ }): Promise<{
30
+ id: string;
31
+ text: string;
32
+ completed: boolean;
33
+ createdAt: Date;
34
+ updatedAt: Date;
35
+ } | null>;
36
+ export declare function deleteTodo(db: DatabaseClient, id: string): Promise<void>;
37
+ //# sourceMappingURL=todos.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"todos.d.ts","sourceRoot":"","sources":["../../src/queries/todos.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAA;AAGxD,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc;;;;;;KAEnD;AAED,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;UAG/D;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM;;;;;;eAUhE;AAED,wBAAsB,UAAU,CAC9B,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,OAAO,CAAA;CAAE;;;;;;UAY7C;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAE9D"}
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Todo database queries
3
+ */
4
+ import { eq } from 'drizzle-orm';
5
+ import { todos } from '../schema/todos.js';
6
+ export async function getAllTodos(db) {
7
+ return db.select().from(todos).orderBy(todos.createdAt);
8
+ }
9
+ export async function getTodoById(db, id) {
10
+ const result = await db.select().from(todos).where(eq(todos.id, id)).limit(1);
11
+ return result[0] ?? null;
12
+ }
13
+ export async function createTodo(db, text) {
14
+ const result = await db
15
+ .insert(todos)
16
+ .values({
17
+ text,
18
+ completed: false,
19
+ })
20
+ .returning();
21
+ return result[0];
22
+ }
23
+ export async function updateTodo(db, id, data) {
24
+ const result = await db
25
+ .update(todos)
26
+ .set({
27
+ ...data,
28
+ updatedAt: new Date(),
29
+ })
30
+ .where(eq(todos.id, id))
31
+ .returning();
32
+ return result[0] ?? null;
33
+ }
34
+ export async function deleteTodo(db, id) {
35
+ await db.delete(todos).where(eq(todos.id, id));
36
+ }
37
+ //# sourceMappingURL=todos.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"todos.js","sourceRoot":"","sources":["../../src/queries/todos.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAA;AAEhC,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAA;AAE1C,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,EAAkB;IAClD,OAAO,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;AACzD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,EAAkB,EAAE,EAAU;IAC9D,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;IAC7E,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAA;AAC1B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,EAAkB,EAAE,IAAY;IAC/D,MAAM,MAAM,GAAG,MAAM,EAAE;SACpB,MAAM,CAAC,KAAK,CAAC;SACb,MAAM,CAAC;QACN,IAAI;QACJ,SAAS,EAAE,KAAK;KACjB,CAAC;SACD,SAAS,EAAE,CAAA;IAEd,OAAO,MAAM,CAAC,CAAC,CAAC,CAAA;AAClB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,EAAkB,EAClB,EAAU,EACV,IAA4C;IAE5C,MAAM,MAAM,GAAG,MAAM,EAAE;SACpB,MAAM,CAAC,KAAK,CAAC;SACb,GAAG,CAAC;QACH,GAAG,IAAI;QACP,SAAS,EAAE,IAAI,IAAI,EAAE;KACtB,CAAC;SACD,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;SACvB,SAAS,EAAE,CAAA;IAEd,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAA;AAC1B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,EAAkB,EAAE,EAAU;IAC7D,MAAM,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;AAChD,CAAC"}