@payloadcms/db-sqlite 3.7.0 → 3.7.1-canary.6b01088

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 (42) hide show
  1. package/dist/index.d.ts.map +1 -1
  2. package/dist/index.js +2 -0
  3. package/dist/index.js.map +1 -1
  4. package/dist/init.d.ts.map +1 -1
  5. package/dist/init.js +19 -101
  6. package/dist/init.js.map +1 -1
  7. package/dist/schema/buildDrizzleTable.d.ts +3 -0
  8. package/dist/schema/buildDrizzleTable.d.ts.map +1 -0
  9. package/dist/schema/buildDrizzleTable.js +135 -0
  10. package/dist/schema/buildDrizzleTable.js.map +1 -0
  11. package/dist/schema/setColumnID.d.ts +2 -9
  12. package/dist/schema/setColumnID.d.ts.map +1 -1
  13. package/dist/schema/setColumnID.js +15 -4
  14. package/dist/schema/setColumnID.js.map +1 -1
  15. package/dist/types.d.ts +13 -6
  16. package/dist/types.d.ts.map +1 -1
  17. package/dist/types.js.map +1 -1
  18. package/package.json +4 -4
  19. package/dist/schema/build.d.ts +0 -52
  20. package/dist/schema/build.d.ts.map +0 -1
  21. package/dist/schema/build.js +0 -440
  22. package/dist/schema/build.js.map +0 -1
  23. package/dist/schema/createIndex.d.ts +0 -11
  24. package/dist/schema/createIndex.d.ts.map +0 -1
  25. package/dist/schema/createIndex.js +0 -20
  26. package/dist/schema/createIndex.js.map +0 -1
  27. package/dist/schema/getIDColumn.d.ts +0 -8
  28. package/dist/schema/getIDColumn.d.ts.map +0 -1
  29. package/dist/schema/getIDColumn.js +0 -24
  30. package/dist/schema/getIDColumn.js.map +0 -1
  31. package/dist/schema/idToUUID.d.ts +0 -3
  32. package/dist/schema/idToUUID.d.ts.map +0 -1
  33. package/dist/schema/idToUUID.js +0 -11
  34. package/dist/schema/idToUUID.js.map +0 -1
  35. package/dist/schema/traverseFields.d.ts +0 -44
  36. package/dist/schema/traverseFields.d.ts.map +0 -1
  37. package/dist/schema/traverseFields.js +0 -610
  38. package/dist/schema/traverseFields.js.map +0 -1
  39. package/dist/schema/withDefault.d.ts +0 -4
  40. package/dist/schema/withDefault.d.ts.map +0 -1
  41. package/dist/schema/withDefault.js +0 -12
  42. package/dist/schema/withDefault.js.map +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-sqlite",
3
- "version": "3.7.0",
3
+ "version": "3.7.1-canary.6b01088",
4
4
  "description": "The officially supported SQLite database adapter for Payload",
5
5
  "homepage": "https://payloadcms.com",
6
6
  "repository": {
@@ -49,16 +49,16 @@
49
49
  "prompts": "2.4.2",
50
50
  "to-snake-case": "1.0.0",
51
51
  "uuid": "9.0.0",
52
- "@payloadcms/drizzle": "3.7.0"
52
+ "@payloadcms/drizzle": "3.7.1-canary.6b01088"
53
53
  },
54
54
  "devDependencies": {
55
55
  "@types/pg": "8.10.2",
56
56
  "@types/to-snake-case": "1.0.0",
57
57
  "@payloadcms/eslint-config": "3.0.0",
58
- "payload": "3.7.0"
58
+ "payload": "3.7.1-canary.6b01088"
59
59
  },
60
60
  "peerDependencies": {
61
- "payload": "3.7.0"
61
+ "payload": "3.7.1-canary.6b01088"
62
62
  },
63
63
  "scripts": {
64
64
  "build": "pnpm build:swc && pnpm build:types",
@@ -1,52 +0,0 @@
1
- import type { AnySQLiteColumn, ForeignKeyBuilder, IndexBuilder, SQLiteColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/sqlite-core';
2
- import type { FlattenedField } from 'payload';
3
- import type { IDType, SQLiteAdapter } from '../types.js';
4
- export type BaseExtraConfig = Record<string, (cols: {
5
- [x: string]: AnySQLiteColumn;
6
- }) => ForeignKeyBuilder | IndexBuilder | UniqueConstraintBuilder>;
7
- export type RelationMap = Map<string, {
8
- localized: boolean;
9
- relationName?: string;
10
- target: string;
11
- type: 'many' | 'one';
12
- }>;
13
- type Args = {
14
- adapter: SQLiteAdapter;
15
- baseColumns?: Record<string, SQLiteColumnBuilder>;
16
- /**
17
- * After table is created, run these functions to add extra config to the table
18
- * ie. indexes, multiple columns, etc
19
- */
20
- baseExtraConfig?: BaseExtraConfig;
21
- buildNumbers?: boolean;
22
- buildRelationships?: boolean;
23
- disableNotNull: boolean;
24
- disableRelsTableUnique?: boolean;
25
- disableUnique: boolean;
26
- fields: FlattenedField[];
27
- locales?: [string, ...string[]];
28
- rootRelationships?: Set<string>;
29
- rootRelationsToBuild?: RelationMap;
30
- rootTableIDColType?: IDType;
31
- rootTableName?: string;
32
- rootUniqueRelationships?: Set<string>;
33
- tableName: string;
34
- timestamps?: boolean;
35
- versions: boolean;
36
- /**
37
- * Tracks whether or not this table is built
38
- * from the result of a localized array or block field at some point
39
- */
40
- withinLocalizedArrayOrBlock?: boolean;
41
- };
42
- type Result = {
43
- hasLocalizedManyNumberField: boolean;
44
- hasLocalizedManyTextField: boolean;
45
- hasLocalizedRelationshipField: boolean;
46
- hasManyNumberField: 'index' | boolean;
47
- hasManyTextField: 'index' | boolean;
48
- relationsToBuild: RelationMap;
49
- };
50
- export declare const buildTable: ({ adapter, baseColumns, baseExtraConfig, disableNotNull, disableRelsTableUnique, disableUnique, fields, locales, rootRelationships, rootRelationsToBuild, rootTableIDColType, rootTableName: incomingRootTableName, rootUniqueRelationships, tableName, timestamps, versions, withinLocalizedArrayOrBlock, }: Args) => Result;
51
- export {};
52
- //# sourceMappingURL=build.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,eAAe,EACf,iBAAiB,EACjB,YAAY,EACZ,mBAAmB,EAEnB,uBAAuB,EACxB,MAAM,yBAAyB,CAAA;AAChC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAe7C,OAAO,KAAK,EAAgC,MAAM,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAOtF,MAAM,MAAM,eAAe,GAAG,MAAM,CAClC,MAAM,EACN,CAAC,IAAI,EAAE;IACL,CAAC,CAAC,EAAE,MAAM,GAAG,eAAe,CAAA;CAC7B,KAAK,iBAAiB,GAAG,YAAY,GAAG,uBAAuB,CACjE,CAAA;AAED,MAAM,MAAM,WAAW,GAAG,GAAG,CAC3B,MAAM,EACN;IACE,SAAS,EAAE,OAAO,CAAA;IAClB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,GAAG,KAAK,CAAA;CACrB,CACF,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,aAAa,CAAA;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAA;IACjD;;;OAGG;IACH,eAAe,CAAC,EAAE,eAAe,CAAA;IACjC,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,cAAc,EAAE,OAAO,CAAA;IACvB,sBAAsB,CAAC,EAAE,OAAO,CAAA;IAChC,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,cAAc,EAAE,CAAA;IACxB,OAAO,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,MAAM,EAAE,CAAC,CAAA;IAC/B,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,oBAAoB,CAAC,EAAE,WAAW,CAAA;IAClC,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,uBAAuB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IACrC,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,OAAO,CAAA;IACjB;;;OAGG;IACH,2BAA2B,CAAC,EAAE,OAAO,CAAA;CACtC,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,gBAAgB,EAAE,WAAW,CAAA;CAC9B,CAAA;AAED,eAAO,MAAM,UAAU,iTAkBpB,IAAI,KAAG,MAqbT,CAAA"}
@@ -1,440 +0,0 @@
1
- import { buildIndexName, createTableName } from '@payloadcms/drizzle';
2
- import { relations, sql } from 'drizzle-orm';
3
- import { foreignKey, index, integer, numeric, sqliteTable, text, unique } from 'drizzle-orm/sqlite-core';
4
- import toSnakeCase from 'to-snake-case';
5
- import { createIndex } from './createIndex.js';
6
- import { getIDColumn } from './getIDColumn.js';
7
- import { setColumnID } from './setColumnID.js';
8
- import { traverseFields } from './traverseFields.js';
9
- export const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, disableNotNull, disableRelsTableUnique, disableUnique = false, fields, locales, rootRelationships, rootRelationsToBuild, rootTableIDColType, rootTableName: incomingRootTableName, rootUniqueRelationships, tableName, timestamps, versions, withinLocalizedArrayOrBlock })=>{
10
- const isRoot = !incomingRootTableName;
11
- const rootTableName = incomingRootTableName || tableName;
12
- const columns = baseColumns;
13
- const indexes = {};
14
- const localesColumns = {};
15
- const localesIndexes = {};
16
- let localesTable;
17
- let textsTable;
18
- let numbersTable;
19
- // Relationships to the base collection
20
- const relationships = rootRelationships || new Set();
21
- const uniqueRelationships = rootUniqueRelationships || new Set();
22
- let relationshipsTable;
23
- // Drizzle relations
24
- const relationsToBuild = new Map();
25
- const idColType = setColumnID({
26
- columns,
27
- fields
28
- });
29
- const { hasLocalizedField, hasLocalizedManyNumberField, hasLocalizedManyTextField, hasLocalizedRelationshipField, hasManyNumberField, hasManyTextField } = traverseFields({
30
- adapter,
31
- columns,
32
- disableNotNull,
33
- disableRelsTableUnique,
34
- disableUnique,
35
- fields,
36
- indexes,
37
- locales,
38
- localesColumns,
39
- localesIndexes,
40
- newTableName: tableName,
41
- parentTableName: tableName,
42
- relationships,
43
- relationsToBuild,
44
- rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,
45
- rootTableIDColType: rootTableIDColType || idColType,
46
- rootTableName,
47
- uniqueRelationships,
48
- versions,
49
- withinLocalizedArrayOrBlock
50
- });
51
- // split the relationsToBuild by localized and non-localized
52
- const localizedRelations = new Map();
53
- const nonLocalizedRelations = new Map();
54
- relationsToBuild.forEach(({ type, localized, relationName, target }, key)=>{
55
- const map = localized ? localizedRelations : nonLocalizedRelations;
56
- map.set(key, {
57
- type,
58
- relationName,
59
- target
60
- });
61
- });
62
- if (timestamps) {
63
- columns.createdAt = text('created_at').default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`).notNull();
64
- columns.updatedAt = text('updated_at').default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`).notNull();
65
- }
66
- const table = sqliteTable(tableName, columns, (cols)=>{
67
- const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func])=>{
68
- config[key] = func(cols);
69
- return config;
70
- }, {});
71
- const result = Object.entries(indexes).reduce((acc, [colName, func])=>{
72
- acc[colName] = func(cols);
73
- return acc;
74
- }, extraConfig);
75
- return result;
76
- });
77
- adapter.tables[tableName] = table;
78
- if (hasLocalizedField || localizedRelations.size) {
79
- const localeTableName = `${tableName}${adapter.localesSuffix}`;
80
- localesColumns.id = integer('id', {
81
- mode: 'number'
82
- }).primaryKey({
83
- autoIncrement: true
84
- });
85
- localesColumns._locale = text('_locale', {
86
- enum: locales
87
- }).notNull();
88
- localesColumns._parentID = getIDColumn({
89
- name: '_parent_id',
90
- type: idColType,
91
- notNull: true,
92
- primaryKey: false
93
- });
94
- localesTable = sqliteTable(localeTableName, localesColumns, (cols)=>{
95
- return Object.entries(localesIndexes).reduce((acc, [colName, func])=>{
96
- acc[colName] = func(cols);
97
- return acc;
98
- }, {
99
- _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(cols._locale, cols._parentID),
100
- _parentIdFk: foreignKey({
101
- name: `${localeTableName}_parent_id_fk`,
102
- columns: [
103
- cols._parentID
104
- ],
105
- foreignColumns: [
106
- table.id
107
- ]
108
- }).onDelete('cascade')
109
- });
110
- });
111
- adapter.tables[localeTableName] = localesTable;
112
- adapter.relations[`relations_${localeTableName}`] = relations(localesTable, ({ many, one })=>{
113
- const result = {};
114
- result._parentID = one(table, {
115
- fields: [
116
- localesTable._parentID
117
- ],
118
- references: [
119
- table.id
120
- ],
121
- // name the relationship by what the many() relationName is
122
- relationName: '_locales'
123
- });
124
- localizedRelations.forEach(({ type, target }, key)=>{
125
- if (type === 'one') {
126
- result[key] = one(adapter.tables[target], {
127
- fields: [
128
- localesTable[key]
129
- ],
130
- references: [
131
- adapter.tables[target].id
132
- ],
133
- relationName: key
134
- });
135
- }
136
- if (type === 'many') {
137
- result[key] = many(adapter.tables[target], {
138
- relationName: key
139
- });
140
- }
141
- });
142
- return result;
143
- });
144
- }
145
- if (isRoot) {
146
- if (hasManyTextField) {
147
- const textsTableName = `${rootTableName}_texts`;
148
- const columns = {
149
- id: integer('id', {
150
- mode: 'number'
151
- }).primaryKey({
152
- autoIncrement: true
153
- }),
154
- order: integer('order').notNull(),
155
- parent: getIDColumn({
156
- name: 'parent_id',
157
- type: idColType,
158
- notNull: true,
159
- primaryKey: false
160
- }),
161
- path: text('path').notNull(),
162
- text: text('text')
163
- };
164
- if (hasLocalizedManyTextField) {
165
- columns.locale = text('locale', {
166
- enum: locales
167
- });
168
- }
169
- textsTable = sqliteTable(textsTableName, columns, (cols)=>{
170
- const config = {
171
- orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),
172
- parentFk: foreignKey({
173
- name: `${textsTableName}_parent_fk`,
174
- columns: [
175
- cols.parent
176
- ],
177
- foreignColumns: [
178
- table.id
179
- ]
180
- }).onDelete('cascade')
181
- };
182
- if (hasManyTextField === 'index') {
183
- config.text_idx = index(`${textsTableName}_text_idx`).on(cols.text);
184
- }
185
- if (hasLocalizedManyTextField) {
186
- config.localeParent = index(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent);
187
- }
188
- return config;
189
- });
190
- adapter.tables[textsTableName] = textsTable;
191
- adapter.relations[`relations_${textsTableName}`] = relations(textsTable, ({ one })=>({
192
- parent: one(table, {
193
- fields: [
194
- textsTable.parent
195
- ],
196
- references: [
197
- table.id
198
- ],
199
- relationName: '_texts'
200
- })
201
- }));
202
- }
203
- if (hasManyNumberField) {
204
- const numbersTableName = `${rootTableName}_numbers`;
205
- const columns = {
206
- id: integer('id', {
207
- mode: 'number'
208
- }).primaryKey({
209
- autoIncrement: true
210
- }),
211
- number: numeric('number'),
212
- order: integer('order').notNull(),
213
- parent: getIDColumn({
214
- name: 'parent_id',
215
- type: idColType,
216
- notNull: true,
217
- primaryKey: false
218
- }),
219
- path: text('path').notNull()
220
- };
221
- if (hasLocalizedManyNumberField) {
222
- columns.locale = text('locale', {
223
- enum: locales
224
- });
225
- }
226
- numbersTable = sqliteTable(numbersTableName, columns, (cols)=>{
227
- const config = {
228
- orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),
229
- parentFk: foreignKey({
230
- name: `${numbersTableName}_parent_fk`,
231
- columns: [
232
- cols.parent
233
- ],
234
- foreignColumns: [
235
- table.id
236
- ]
237
- }).onDelete('cascade')
238
- };
239
- if (hasManyNumberField === 'index') {
240
- config.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number);
241
- }
242
- if (hasLocalizedManyNumberField) {
243
- config.localeParent = index(`${numbersTableName}_locale_parent`).on(cols.locale, cols.parent);
244
- }
245
- return config;
246
- });
247
- adapter.tables[numbersTableName] = numbersTable;
248
- adapter.relations[`relations_${numbersTableName}`] = relations(numbersTable, ({ one })=>({
249
- parent: one(table, {
250
- fields: [
251
- numbersTable.parent
252
- ],
253
- references: [
254
- table.id
255
- ],
256
- relationName: '_numbers'
257
- })
258
- }));
259
- }
260
- if (relationships.size) {
261
- const relationshipColumns = {
262
- id: integer('id', {
263
- mode: 'number'
264
- }).primaryKey({
265
- autoIncrement: true
266
- }),
267
- order: integer('order'),
268
- parent: getIDColumn({
269
- name: 'parent_id',
270
- type: idColType,
271
- notNull: true,
272
- primaryKey: false
273
- }),
274
- path: text('path').notNull()
275
- };
276
- if (hasLocalizedRelationshipField) {
277
- relationshipColumns.locale = text('locale', {
278
- enum: locales
279
- });
280
- }
281
- const relationExtraConfig = {};
282
- const relationshipsTableName = `${tableName}${adapter.relationshipsSuffix}`;
283
- relationships.forEach((relationTo)=>{
284
- const relationshipConfig = adapter.payload.collections[relationTo].config;
285
- const formattedRelationTo = createTableName({
286
- adapter,
287
- config: relationshipConfig
288
- });
289
- let colType = 'integer';
290
- const relatedCollectionCustomIDType = adapter.payload.collections[relationshipConfig.slug]?.customIDType;
291
- if (relatedCollectionCustomIDType === 'number') {
292
- colType = 'numeric';
293
- }
294
- if (relatedCollectionCustomIDType === 'text') {
295
- colType = 'text';
296
- }
297
- const colName = `${relationTo}ID`;
298
- relationshipColumns[colName] = getIDColumn({
299
- name: `${formattedRelationTo}_id`,
300
- type: colType,
301
- primaryKey: false
302
- });
303
- relationExtraConfig[`${relationTo}IdFk`] = (cols)=>foreignKey({
304
- name: `${relationshipsTableName}_${toSnakeCase(relationTo)}_fk`,
305
- columns: [
306
- cols[colName]
307
- ],
308
- foreignColumns: [
309
- adapter.tables[formattedRelationTo].id
310
- ]
311
- }).onDelete('cascade');
312
- const indexColumns = [
313
- colName
314
- ];
315
- const unique = !disableUnique && uniqueRelationships.has(relationTo);
316
- if (unique) {
317
- indexColumns.push('path');
318
- }
319
- if (hasLocalizedRelationshipField) {
320
- indexColumns.push('locale');
321
- }
322
- const indexName = buildIndexName({
323
- name: `${relationshipsTableName}_${formattedRelationTo}_id`,
324
- adapter: adapter
325
- });
326
- relationExtraConfig[indexName] = createIndex({
327
- name: indexColumns,
328
- indexName,
329
- unique
330
- });
331
- });
332
- relationshipsTable = sqliteTable(relationshipsTableName, relationshipColumns, (cols)=>{
333
- const result = Object.entries(relationExtraConfig).reduce((config, [key, func])=>{
334
- config[key] = func(cols);
335
- return config;
336
- }, {
337
- order: index(`${relationshipsTableName}_order_idx`).on(cols.order),
338
- parentFk: foreignKey({
339
- name: `${relationshipsTableName}_parent_fk`,
340
- columns: [
341
- cols.parent
342
- ],
343
- foreignColumns: [
344
- table.id
345
- ]
346
- }).onDelete('cascade'),
347
- parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),
348
- pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path)
349
- });
350
- if (hasLocalizedRelationshipField) {
351
- result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale);
352
- }
353
- return result;
354
- });
355
- adapter.tables[relationshipsTableName] = relationshipsTable;
356
- adapter.relations[`relations_${relationshipsTableName}`] = relations(relationshipsTable, ({ one })=>{
357
- const result = {
358
- parent: one(table, {
359
- fields: [
360
- relationshipsTable.parent
361
- ],
362
- references: [
363
- table.id
364
- ],
365
- relationName: '_rels'
366
- })
367
- };
368
- relationships.forEach((relationTo)=>{
369
- const relatedTableName = createTableName({
370
- adapter,
371
- config: adapter.payload.collections[relationTo].config
372
- });
373
- const idColumnName = `${relationTo}ID`;
374
- result[idColumnName] = one(adapter.tables[relatedTableName], {
375
- fields: [
376
- relationshipsTable[idColumnName]
377
- ],
378
- references: [
379
- adapter.tables[relatedTableName].id
380
- ],
381
- relationName: relationTo
382
- });
383
- });
384
- return result;
385
- });
386
- }
387
- }
388
- adapter.relations[`relations_${tableName}`] = relations(table, ({ many, one })=>{
389
- const result = {};
390
- nonLocalizedRelations.forEach(({ type, relationName, target }, key)=>{
391
- if (type === 'one') {
392
- result[key] = one(adapter.tables[target], {
393
- fields: [
394
- table[key]
395
- ],
396
- references: [
397
- adapter.tables[target].id
398
- ],
399
- relationName: key
400
- });
401
- }
402
- if (type === 'many') {
403
- result[key] = many(adapter.tables[target], {
404
- relationName: relationName || key
405
- });
406
- }
407
- });
408
- if (hasLocalizedField) {
409
- result._locales = many(localesTable, {
410
- relationName: '_locales'
411
- });
412
- }
413
- if (hasManyTextField) {
414
- result._texts = many(textsTable, {
415
- relationName: '_texts'
416
- });
417
- }
418
- if (hasManyNumberField) {
419
- result._numbers = many(numbersTable, {
420
- relationName: '_numbers'
421
- });
422
- }
423
- if (relationships.size && relationshipsTable) {
424
- result._rels = many(relationshipsTable, {
425
- relationName: '_rels'
426
- });
427
- }
428
- return result;
429
- });
430
- return {
431
- hasLocalizedManyNumberField,
432
- hasLocalizedManyTextField,
433
- hasLocalizedRelationshipField,
434
- hasManyNumberField,
435
- hasManyTextField,
436
- relationsToBuild
437
- };
438
- };
439
-
440
- //# sourceMappingURL=build.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["import type { DrizzleAdapter } from '@payloadcms/drizzle/types'\nimport type { Relation } from 'drizzle-orm'\nimport type {\n AnySQLiteColumn,\n ForeignKeyBuilder,\n IndexBuilder,\n SQLiteColumnBuilder,\n SQLiteTableWithColumns,\n UniqueConstraintBuilder,\n} from 'drizzle-orm/sqlite-core'\nimport type { FlattenedField } from 'payload'\n\nimport { buildIndexName, createTableName } from '@payloadcms/drizzle'\nimport { relations, sql } from 'drizzle-orm'\nimport {\n foreignKey,\n index,\n integer,\n numeric,\n sqliteTable,\n text,\n unique,\n} from 'drizzle-orm/sqlite-core'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, IDType, SQLiteAdapter } from '../types.js'\n\nimport { createIndex } from './createIndex.js'\nimport { getIDColumn } from './getIDColumn.js'\nimport { setColumnID } from './setColumnID.js'\nimport { traverseFields } from './traverseFields.js'\n\nexport type BaseExtraConfig = Record<\n string,\n (cols: {\n [x: string]: AnySQLiteColumn\n }) => ForeignKeyBuilder | IndexBuilder | UniqueConstraintBuilder\n>\n\nexport type RelationMap = Map<\n string,\n {\n localized: boolean\n relationName?: string\n target: string\n type: 'many' | 'one'\n }\n>\n\ntype Args = {\n adapter: SQLiteAdapter\n baseColumns?: Record<string, SQLiteColumnBuilder>\n /**\n * After table is created, run these functions to add extra config to the table\n * ie. indexes, multiple columns, etc\n */\n baseExtraConfig?: BaseExtraConfig\n buildNumbers?: boolean\n buildRelationships?: boolean\n disableNotNull: boolean\n disableRelsTableUnique?: boolean\n disableUnique: boolean\n fields: FlattenedField[]\n locales?: [string, ...string[]]\n rootRelationships?: Set<string>\n rootRelationsToBuild?: RelationMap\n rootTableIDColType?: IDType\n rootTableName?: string\n rootUniqueRelationships?: Set<string>\n tableName: string\n timestamps?: boolean\n versions: boolean\n /**\n * Tracks whether or not this table is built\n * from the result of a localized array or block field at some point\n */\n withinLocalizedArrayOrBlock?: boolean\n}\n\ntype Result = {\n hasLocalizedManyNumberField: boolean\n hasLocalizedManyTextField: boolean\n hasLocalizedRelationshipField: boolean\n hasManyNumberField: 'index' | boolean\n hasManyTextField: 'index' | boolean\n relationsToBuild: RelationMap\n}\n\nexport const buildTable = ({\n adapter,\n baseColumns = {},\n baseExtraConfig = {},\n disableNotNull,\n disableRelsTableUnique,\n disableUnique = false,\n fields,\n locales,\n rootRelationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName: incomingRootTableName,\n rootUniqueRelationships,\n tableName,\n timestamps,\n versions,\n withinLocalizedArrayOrBlock,\n}: Args): Result => {\n const isRoot = !incomingRootTableName\n const rootTableName = incomingRootTableName || tableName\n const columns: Record<string, SQLiteColumnBuilder> = baseColumns\n const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n const localesColumns: Record<string, SQLiteColumnBuilder> = {}\n const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n let localesTable: GenericTable | SQLiteTableWithColumns<any>\n let textsTable: GenericTable | SQLiteTableWithColumns<any>\n let numbersTable: GenericTable | SQLiteTableWithColumns<any>\n\n // Relationships to the base collection\n const relationships: Set<string> = rootRelationships || new Set()\n const uniqueRelationships: Set<string> = rootUniqueRelationships || new Set()\n\n let relationshipsTable: GenericTable | SQLiteTableWithColumns<any>\n\n // Drizzle relations\n const relationsToBuild: RelationMap = new Map()\n\n const idColType: IDType = setColumnID({ columns, fields })\n\n const {\n hasLocalizedField,\n hasLocalizedManyNumberField,\n hasLocalizedManyTextField,\n hasLocalizedRelationshipField,\n hasManyNumberField,\n hasManyTextField,\n } = traverseFields({\n adapter,\n columns,\n disableNotNull,\n disableRelsTableUnique,\n disableUnique,\n fields,\n indexes,\n locales,\n localesColumns,\n localesIndexes,\n newTableName: tableName,\n parentTableName: tableName,\n relationships,\n relationsToBuild,\n rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n rootTableIDColType: rootTableIDColType || idColType,\n rootTableName,\n uniqueRelationships,\n versions,\n withinLocalizedArrayOrBlock,\n })\n\n // split the relationsToBuild by localized and non-localized\n const localizedRelations = new Map()\n const nonLocalizedRelations = new Map()\n\n relationsToBuild.forEach(({ type, localized, relationName, target }, key) => {\n const map = localized ? localizedRelations : nonLocalizedRelations\n map.set(key, { type, relationName, target })\n })\n\n if (timestamps) {\n columns.createdAt = text('created_at')\n .default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`)\n .notNull()\n columns.updatedAt = text('updated_at')\n .default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`)\n .notNull()\n }\n\n const table = sqliteTable(tableName, columns, (cols) => {\n const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n config[key] = func(cols)\n return config\n }, {})\n\n const result = Object.entries(indexes).reduce((acc, [colName, func]) => {\n acc[colName] = func(cols)\n return acc\n }, extraConfig)\n\n return result\n })\n\n adapter.tables[tableName] = table\n\n if (hasLocalizedField || localizedRelations.size) {\n const localeTableName = `${tableName}${adapter.localesSuffix}`\n localesColumns.id = integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true })\n localesColumns._locale = text('_locale', { enum: locales }).notNull()\n localesColumns._parentID = getIDColumn({\n name: '_parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n })\n\n localesTable = sqliteTable(localeTableName, localesColumns, (cols) => {\n return Object.entries(localesIndexes).reduce(\n (acc, [colName, func]) => {\n acc[colName] = func(cols)\n return acc\n },\n {\n _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n cols._locale,\n cols._parentID,\n ),\n _parentIdFk: foreignKey({\n name: `${localeTableName}_parent_id_fk`,\n columns: [cols._parentID],\n foreignColumns: [table.id],\n }).onDelete('cascade'),\n },\n )\n })\n\n adapter.tables[localeTableName] = localesTable\n\n adapter.relations[`relations_${localeTableName}`] = relations(localesTable, ({ many, one }) => {\n const result: Record<string, Relation<string>> = {}\n\n result._parentID = one(table, {\n fields: [localesTable._parentID],\n references: [table.id],\n // name the relationship by what the many() relationName is\n relationName: '_locales',\n })\n\n localizedRelations.forEach(({ type, target }, key) => {\n if (type === 'one') {\n result[key] = one(adapter.tables[target], {\n fields: [localesTable[key]],\n references: [adapter.tables[target].id],\n relationName: key,\n })\n }\n if (type === 'many') {\n result[key] = many(adapter.tables[target], {\n relationName: key,\n })\n }\n })\n\n return result\n })\n }\n\n if (isRoot) {\n if (hasManyTextField) {\n const textsTableName = `${rootTableName}_texts`\n const columns: Record<string, SQLiteColumnBuilder> = {\n id: integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true }),\n order: integer('order').notNull(),\n parent: getIDColumn({\n name: 'parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n }),\n path: text('path').notNull(),\n text: text('text'),\n }\n\n if (hasLocalizedManyTextField) {\n columns.locale = text('locale', { enum: locales })\n }\n\n textsTable = sqliteTable(textsTableName, columns, (cols) => {\n const config: Record<string, ForeignKeyBuilder | IndexBuilder> = {\n orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),\n parentFk: foreignKey({\n name: `${textsTableName}_parent_fk`,\n columns: [cols.parent],\n foreignColumns: [table.id],\n }).onDelete('cascade'),\n }\n\n if (hasManyTextField === 'index') {\n config.text_idx = index(`${textsTableName}_text_idx`).on(cols.text)\n }\n\n if (hasLocalizedManyTextField) {\n config.localeParent = index(`${textsTableName}_locale_parent`).on(\n cols.locale,\n cols.parent,\n )\n }\n\n return config\n })\n\n adapter.tables[textsTableName] = textsTable\n\n adapter.relations[`relations_${textsTableName}`] = relations(textsTable, ({ one }) => ({\n parent: one(table, {\n fields: [textsTable.parent],\n references: [table.id],\n relationName: '_texts',\n }),\n }))\n }\n\n if (hasManyNumberField) {\n const numbersTableName = `${rootTableName}_numbers`\n const columns: Record<string, SQLiteColumnBuilder> = {\n id: integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true }),\n number: numeric('number'),\n order: integer('order').notNull(),\n parent: getIDColumn({\n name: 'parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n }),\n path: text('path').notNull(),\n }\n\n if (hasLocalizedManyNumberField) {\n columns.locale = text('locale', { enum: locales })\n }\n\n numbersTable = sqliteTable(numbersTableName, columns, (cols) => {\n const config: Record<string, ForeignKeyBuilder | IndexBuilder> = {\n orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),\n parentFk: foreignKey({\n name: `${numbersTableName}_parent_fk`,\n columns: [cols.parent],\n foreignColumns: [table.id],\n }).onDelete('cascade'),\n }\n\n if (hasManyNumberField === 'index') {\n config.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number)\n }\n\n if (hasLocalizedManyNumberField) {\n config.localeParent = index(`${numbersTableName}_locale_parent`).on(\n cols.locale,\n cols.parent,\n )\n }\n\n return config\n })\n\n adapter.tables[numbersTableName] = numbersTable\n\n adapter.relations[`relations_${numbersTableName}`] = relations(numbersTable, ({ one }) => ({\n parent: one(table, {\n fields: [numbersTable.parent],\n references: [table.id],\n relationName: '_numbers',\n }),\n }))\n }\n\n if (relationships.size) {\n const relationshipColumns: Record<string, SQLiteColumnBuilder> = {\n id: integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true }),\n order: integer('order'),\n parent: getIDColumn({\n name: 'parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n }),\n path: text('path').notNull(),\n }\n\n if (hasLocalizedRelationshipField) {\n relationshipColumns.locale = text('locale', { enum: locales })\n }\n\n const relationExtraConfig: BaseExtraConfig = {}\n const relationshipsTableName = `${tableName}${adapter.relationshipsSuffix}`\n\n relationships.forEach((relationTo) => {\n const relationshipConfig = adapter.payload.collections[relationTo].config\n const formattedRelationTo = createTableName({\n adapter,\n config: relationshipConfig,\n })\n let colType: IDType = 'integer'\n const relatedCollectionCustomIDType =\n adapter.payload.collections[relationshipConfig.slug]?.customIDType\n\n if (relatedCollectionCustomIDType === 'number') {\n colType = 'numeric'\n }\n if (relatedCollectionCustomIDType === 'text') {\n colType = 'text'\n }\n\n const colName = `${relationTo}ID`\n\n relationshipColumns[colName] = getIDColumn({\n name: `${formattedRelationTo}_id`,\n type: colType,\n primaryKey: false,\n })\n\n relationExtraConfig[`${relationTo}IdFk`] = (cols) =>\n foreignKey({\n name: `${relationshipsTableName}_${toSnakeCase(relationTo)}_fk`,\n columns: [cols[colName]],\n foreignColumns: [adapter.tables[formattedRelationTo].id],\n }).onDelete('cascade')\n\n const indexColumns = [colName]\n\n const unique = !disableUnique && uniqueRelationships.has(relationTo)\n\n if (unique) {\n indexColumns.push('path')\n }\n if (hasLocalizedRelationshipField) {\n indexColumns.push('locale')\n }\n\n const indexName = buildIndexName({\n name: `${relationshipsTableName}_${formattedRelationTo}_id`,\n adapter: adapter as unknown as DrizzleAdapter,\n })\n\n relationExtraConfig[indexName] = createIndex({\n name: indexColumns,\n indexName,\n unique,\n })\n })\n\n relationshipsTable = sqliteTable(relationshipsTableName, relationshipColumns, (cols) => {\n const result: Record<string, ForeignKeyBuilder | IndexBuilder> = Object.entries(\n relationExtraConfig,\n ).reduce(\n (config, [key, func]) => {\n config[key] = func(cols)\n return config\n },\n {\n order: index(`${relationshipsTableName}_order_idx`).on(cols.order),\n parentFk: foreignKey({\n name: `${relationshipsTableName}_parent_fk`,\n columns: [cols.parent],\n foreignColumns: [table.id],\n }).onDelete('cascade'),\n parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),\n pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path),\n },\n )\n\n if (hasLocalizedRelationshipField) {\n result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale)\n }\n\n return result\n })\n\n adapter.tables[relationshipsTableName] = relationshipsTable\n\n adapter.relations[`relations_${relationshipsTableName}`] = relations(\n relationshipsTable,\n ({ one }) => {\n const result: Record<string, Relation<string>> = {\n parent: one(table, {\n fields: [relationshipsTable.parent],\n references: [table.id],\n relationName: '_rels',\n }),\n }\n\n relationships.forEach((relationTo) => {\n const relatedTableName = createTableName({\n adapter,\n config: adapter.payload.collections[relationTo].config,\n })\n const idColumnName = `${relationTo}ID`\n result[idColumnName] = one(adapter.tables[relatedTableName], {\n fields: [relationshipsTable[idColumnName]],\n references: [adapter.tables[relatedTableName].id],\n relationName: relationTo,\n })\n })\n\n return result\n },\n )\n }\n }\n\n adapter.relations[`relations_${tableName}`] = relations(table, ({ many, one }) => {\n const result: Record<string, Relation<string>> = {}\n\n nonLocalizedRelations.forEach(({ type, relationName, target }, key) => {\n if (type === 'one') {\n result[key] = one(adapter.tables[target], {\n fields: [table[key]],\n references: [adapter.tables[target].id],\n relationName: key,\n })\n }\n if (type === 'many') {\n result[key] = many(adapter.tables[target], { relationName: relationName || key })\n }\n })\n\n if (hasLocalizedField) {\n result._locales = many(localesTable, { relationName: '_locales' })\n }\n\n if (hasManyTextField) {\n result._texts = many(textsTable, { relationName: '_texts' })\n }\n\n if (hasManyNumberField) {\n result._numbers = many(numbersTable, { relationName: '_numbers' })\n }\n\n if (relationships.size && relationshipsTable) {\n result._rels = many(relationshipsTable, {\n relationName: '_rels',\n })\n }\n\n return result\n })\n\n return {\n hasLocalizedManyNumberField,\n hasLocalizedManyTextField,\n hasLocalizedRelationshipField,\n hasManyNumberField,\n hasManyTextField,\n relationsToBuild,\n }\n}\n"],"names":["buildIndexName","createTableName","relations","sql","foreignKey","index","integer","numeric","sqliteTable","text","unique","toSnakeCase","createIndex","getIDColumn","setColumnID","traverseFields","buildTable","adapter","baseColumns","baseExtraConfig","disableNotNull","disableRelsTableUnique","disableUnique","fields","locales","rootRelationships","rootRelationsToBuild","rootTableIDColType","rootTableName","incomingRootTableName","rootUniqueRelationships","tableName","timestamps","versions","withinLocalizedArrayOrBlock","isRoot","columns","indexes","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","uniqueRelationships","relationshipsTable","relationsToBuild","Map","idColType","hasLocalizedField","hasLocalizedManyNumberField","hasLocalizedManyTextField","hasLocalizedRelationshipField","hasManyNumberField","hasManyTextField","newTableName","parentTableName","localizedRelations","nonLocalizedRelations","forEach","type","localized","relationName","target","key","map","set","createdAt","default","notNull","updatedAt","table","cols","extraConfig","Object","entries","reduce","config","func","result","acc","colName","tables","size","localeTableName","localesSuffix","id","mode","primaryKey","autoIncrement","_locale","enum","_parentID","name","_localeParent","on","_parentIdFk","foreignColumns","onDelete","many","one","references","textsTableName","order","parent","path","locale","orderParentIdx","parentFk","text_idx","localeParent","numbersTableName","number","numberIdx","relationshipColumns","relationExtraConfig","relationshipsTableName","relationshipsSuffix","relationTo","relationshipConfig","payload","collections","formattedRelationTo","colType","relatedCollectionCustomIDType","slug","customIDType","indexColumns","has","push","indexName","parentIdx","pathIdx","localeIdx","relatedTableName","idColumnName","_locales","_texts","_numbers","_rels"],"mappings":"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"}
@@ -1,11 +0,0 @@
1
- import type { AnySQLiteColumn } from 'drizzle-orm/sqlite-core';
2
- type CreateIndexArgs = {
3
- indexName: string;
4
- name: string | string[];
5
- unique?: boolean;
6
- };
7
- export declare const createIndex: ({ name, indexName, unique }: CreateIndexArgs) => (table: {
8
- [x: string]: AnySQLiteColumn;
9
- }) => import("drizzle-orm/sqlite-core").IndexBuilder;
10
- export {};
11
- //# sourceMappingURL=createIndex.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"createIndex.d.ts","sourceRoot":"","sources":["../../src/schema/createIndex.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAI9D,KAAK,eAAe,GAAG;IACrB,SAAS,EAAE,MAAM,CAAA;IACjB,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IACvB,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,WAAW,gCAAiC,eAAe,aACvD;IAAE,CAAC,CAAC,EAAE,MAAM,GAAG,eAAe,CAAA;CAAE,mDAehD,CAAA"}
@@ -1,20 +0,0 @@
1
- import { index, uniqueIndex } from 'drizzle-orm/sqlite-core';
2
- export const createIndex = ({ name, indexName, unique })=>{
3
- return (table)=>{
4
- let columns;
5
- if (Array.isArray(name)) {
6
- columns = name.map((columnName)=>table[columnName])// exclude fields were included in compound indexes but do not exist on the table
7
- .filter((col)=>typeof col !== 'undefined');
8
- } else {
9
- columns = [
10
- table[name]
11
- ];
12
- }
13
- if (unique) {
14
- return uniqueIndex(indexName).on(columns[0], ...columns.slice(1));
15
- }
16
- return index(indexName).on(columns[0], ...columns.slice(1));
17
- };
18
- };
19
-
20
- //# sourceMappingURL=createIndex.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/schema/createIndex.ts"],"sourcesContent":["import type { AnySQLiteColumn } from 'drizzle-orm/sqlite-core'\n\nimport { index, uniqueIndex } from 'drizzle-orm/sqlite-core'\n\ntype CreateIndexArgs = {\n indexName: string\n name: string | string[]\n unique?: boolean\n}\n\nexport const createIndex = ({ name, indexName, unique }: CreateIndexArgs) => {\n return (table: { [x: string]: AnySQLiteColumn }) => {\n let columns\n if (Array.isArray(name)) {\n columns = name\n .map((columnName) => table[columnName])\n // exclude fields were included in compound indexes but do not exist on the table\n .filter((col) => typeof col !== 'undefined')\n } else {\n columns = [table[name]]\n }\n if (unique) {\n return uniqueIndex(indexName).on(columns[0], ...columns.slice(1))\n }\n return index(indexName).on(columns[0], ...columns.slice(1))\n }\n}\n"],"names":["index","uniqueIndex","createIndex","name","indexName","unique","table","columns","Array","isArray","map","columnName","filter","col","on","slice"],"mappings":"AAEA,SAASA,KAAK,EAAEC,WAAW,QAAQ,0BAAyB;AAQ5D,OAAO,MAAMC,cAAc,CAAC,EAAEC,IAAI,EAAEC,SAAS,EAAEC,MAAM,EAAmB;IACtE,OAAO,CAACC;QACN,IAAIC;QACJ,IAAIC,MAAMC,OAAO,CAACN,OAAO;YACvBI,UAAUJ,KACPO,GAAG,CAAC,CAACC,aAAeL,KAAK,CAACK,WAAW,CACtC,iFAAiF;aAChFC,MAAM,CAAC,CAACC,MAAQ,OAAOA,QAAQ;QACpC,OAAO;YACLN,UAAU;gBAACD,KAAK,CAACH,KAAK;aAAC;QACzB;QACA,IAAIE,QAAQ;YACV,OAAOJ,YAAYG,WAAWU,EAAE,CAACP,OAAO,CAAC,EAAE,KAAKA,QAAQQ,KAAK,CAAC;QAChE;QACA,OAAOf,MAAMI,WAAWU,EAAE,CAACP,OAAO,CAAC,EAAE,KAAKA,QAAQQ,KAAK,CAAC;IAC1D;AACF,EAAC"}
@@ -1,8 +0,0 @@
1
- import type { IDType } from '../types.js';
2
- export declare const getIDColumn: ({ name, type, notNull, primaryKey, }: {
3
- name: string;
4
- notNull?: boolean;
5
- primaryKey: boolean;
6
- type: IDType;
7
- }) => any;
8
- //# sourceMappingURL=getIDColumn.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getIDColumn.d.ts","sourceRoot":"","sources":["../../src/schema/getIDColumn.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAEzC,eAAO,MAAM,WAAW,yCAKrB;IACD,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,UAAU,EAAE,OAAO,CAAA;IACnB,IAAI,EAAE,MAAM,CAAA;CACb,QAuBA,CAAA"}