@payloadcms/db-sqlite 3.7.0 → 3.7.1-canary.2ce70a3
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.
- package/dist/columnToCodeConverter.d.ts +3 -0
- package/dist/columnToCodeConverter.d.ts.map +1 -0
- package/dist/columnToCodeConverter.js +92 -0
- package/dist/columnToCodeConverter.js.map +1 -0
- package/dist/drizzle-proxy/index.d.ts +2 -0
- package/dist/drizzle-proxy/index.d.ts.map +1 -0
- package/dist/drizzle-proxy/index.js +3 -0
- package/dist/drizzle-proxy/index.js.map +1 -0
- package/dist/drizzle-proxy/libsql.d.ts +2 -0
- package/dist/drizzle-proxy/libsql.d.ts.map +1 -0
- package/dist/drizzle-proxy/libsql.js +3 -0
- package/dist/drizzle-proxy/libsql.js.map +1 -0
- package/dist/drizzle-proxy/relations.d.ts +2 -0
- package/dist/drizzle-proxy/relations.d.ts.map +1 -0
- package/dist/drizzle-proxy/relations.js +3 -0
- package/dist/drizzle-proxy/relations.js.map +1 -0
- package/dist/drizzle-proxy/sqlite-core.d.ts +2 -0
- package/dist/drizzle-proxy/sqlite-core.d.ts.map +1 -0
- package/dist/drizzle-proxy/sqlite-core.js +3 -0
- package/dist/drizzle-proxy/sqlite-core.js.map +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +10 -1
- package/dist/index.js.map +1 -1
- package/dist/init.d.ts.map +1 -1
- package/dist/init.js +19 -101
- package/dist/init.js.map +1 -1
- package/dist/schema/buildDrizzleTable.d.ts +3 -0
- package/dist/schema/buildDrizzleTable.d.ts.map +1 -0
- package/dist/schema/buildDrizzleTable.js +135 -0
- package/dist/schema/buildDrizzleTable.js.map +1 -0
- package/dist/schema/setColumnID.d.ts +2 -9
- package/dist/schema/setColumnID.d.ts.map +1 -1
- package/dist/schema/setColumnID.js +15 -4
- package/dist/schema/setColumnID.js.map +1 -1
- package/dist/types.d.ts +13 -6
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/package.json +24 -4
- package/dist/schema/build.d.ts +0 -52
- package/dist/schema/build.d.ts.map +0 -1
- package/dist/schema/build.js +0 -440
- package/dist/schema/build.js.map +0 -1
- package/dist/schema/createIndex.d.ts +0 -11
- package/dist/schema/createIndex.d.ts.map +0 -1
- package/dist/schema/createIndex.js +0 -20
- package/dist/schema/createIndex.js.map +0 -1
- package/dist/schema/getIDColumn.d.ts +0 -8
- package/dist/schema/getIDColumn.d.ts.map +0 -1
- package/dist/schema/getIDColumn.js +0 -24
- package/dist/schema/getIDColumn.js.map +0 -1
- package/dist/schema/idToUUID.d.ts +0 -3
- package/dist/schema/idToUUID.d.ts.map +0 -1
- package/dist/schema/idToUUID.js +0 -11
- package/dist/schema/idToUUID.js.map +0 -1
- package/dist/schema/traverseFields.d.ts +0 -44
- package/dist/schema/traverseFields.d.ts.map +0 -1
- package/dist/schema/traverseFields.js +0 -610
- package/dist/schema/traverseFields.js.map +0 -1
- package/dist/schema/withDefault.d.ts +0 -4
- package/dist/schema/withDefault.d.ts.map +0 -1
- package/dist/schema/withDefault.js +0 -12
- package/dist/schema/withDefault.js.map +0 -1
package/dist/schema/build.js
DELETED
|
@@ -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
|
package/dist/schema/build.js.map
DELETED
|
@@ -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 +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"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { integer, numeric, text } from 'drizzle-orm/sqlite-core';
|
|
2
|
-
export const getIDColumn = ({ name, type, notNull, primaryKey })=>{
|
|
3
|
-
let column;
|
|
4
|
-
switch(type){
|
|
5
|
-
case 'integer':
|
|
6
|
-
column = integer(name);
|
|
7
|
-
break;
|
|
8
|
-
case 'numeric':
|
|
9
|
-
column = numeric(name);
|
|
10
|
-
break;
|
|
11
|
-
case 'text':
|
|
12
|
-
column = text(name);
|
|
13
|
-
break;
|
|
14
|
-
}
|
|
15
|
-
if (notNull) {
|
|
16
|
-
column.notNull();
|
|
17
|
-
}
|
|
18
|
-
if (primaryKey) {
|
|
19
|
-
column.primaryKey();
|
|
20
|
-
}
|
|
21
|
-
return column;
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
//# sourceMappingURL=getIDColumn.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/schema/getIDColumn.ts"],"sourcesContent":["import { integer, numeric, text } from 'drizzle-orm/sqlite-core'\n\nimport type { IDType } from '../types.js'\n\nexport const getIDColumn = ({\n name,\n type,\n notNull,\n primaryKey,\n}: {\n name: string\n notNull?: boolean\n primaryKey: boolean\n type: IDType\n}) => {\n let column\n switch (type) {\n case 'integer':\n column = integer(name)\n break\n case 'numeric':\n column = numeric(name)\n break\n case 'text':\n column = text(name)\n break\n }\n\n if (notNull) {\n column.notNull()\n }\n\n if (primaryKey) {\n column.primaryKey()\n }\n\n return column\n}\n"],"names":["integer","numeric","text","getIDColumn","name","type","notNull","primaryKey","column"],"mappings":"AAAA,SAASA,OAAO,EAAEC,OAAO,EAAEC,IAAI,QAAQ,0BAAyB;AAIhE,OAAO,MAAMC,cAAc,CAAC,EAC1BC,IAAI,EACJC,IAAI,EACJC,OAAO,EACPC,UAAU,EAMX;IACC,IAAIC;IACJ,OAAQH;QACN,KAAK;YACHG,SAASR,QAAQI;YACjB;QACF,KAAK;YACHI,SAASP,QAAQG;YACjB;QACF,KAAK;YACHI,SAASN,KAAKE;YACd;IACJ;IAEA,IAAIE,SAAS;QACXE,OAAOF,OAAO;IAChB;IAEA,IAAIC,YAAY;QACdC,OAAOD,UAAU;IACnB;IAEA,OAAOC;AACT,EAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"idToUUID.d.ts","sourceRoot":"","sources":["../../src/schema/idToUUID.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAE7C,eAAO,MAAM,QAAQ,WAAY,cAAc,EAAE,KAAG,cAAc,EAU9D,CAAA"}
|
package/dist/schema/idToUUID.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/schema/idToUUID.ts"],"sourcesContent":["import type { FlattenedField } from 'payload'\n\nexport const idToUUID = (fields: FlattenedField[]): FlattenedField[] =>\n fields.map((field) => {\n if ('name' in field && field.name === 'id') {\n return {\n ...field,\n name: '_uuid',\n }\n }\n\n return field\n })\n"],"names":["idToUUID","fields","map","field","name"],"mappings":"AAEA,OAAO,MAAMA,WAAW,CAACC,SACvBA,OAAOC,GAAG,CAAC,CAACC;QACV,IAAI,UAAUA,SAASA,MAAMC,IAAI,KAAK,MAAM;YAC1C,OAAO;gBACL,GAAGD,KAAK;gBACRC,MAAM;YACR;QACF;QAEA,OAAOD;IACT,GAAE"}
|