@postxl/generator 0.6.4 → 0.6.6
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.
|
@@ -44,8 +44,7 @@ ${imports.generate()}
|
|
|
44
44
|
@Injectable()
|
|
45
45
|
export class ${meta.data.repositoryClassName} implements Repository<
|
|
46
46
|
${model.typeName},
|
|
47
|
-
${idField.unbrandedTypeName}
|
|
48
|
-
Omit<${model.typeName}, 'id'>
|
|
47
|
+
${idField.unbrandedTypeName}
|
|
49
48
|
> {
|
|
50
49
|
protected data: Map<${model.brandedIdType}, ${model.typeName}> = new Map()
|
|
51
50
|
protected logger = new Logger(${meta.data.repositoryClassName}.name)
|
|
@@ -185,8 +184,7 @@ export class ${meta.data.repositoryClassName} implements Repository<
|
|
|
185
184
|
return newItem
|
|
186
185
|
}
|
|
187
186
|
|
|
188
|
-
public async createMany(items:
|
|
189
|
-
const result: ${model.typeName}[] = []
|
|
187
|
+
public async createMany(items: ${model.typeName}[]) {
|
|
190
188
|
${uniqueStringFields.length > 0
|
|
191
189
|
? `
|
|
192
190
|
for (const item of items) {
|
|
@@ -194,18 +192,17 @@ export class ${meta.data.repositoryClassName} implements Repository<
|
|
|
194
192
|
}`
|
|
195
193
|
: ''}
|
|
196
194
|
|
|
197
|
-
await this.db.${meta.data.repository.getMethodFnName}.createMany({ data: items
|
|
195
|
+
await this.db.${meta.data.repository.getMethodFnName}.createMany({ data: items.map(item => ({
|
|
196
|
+
${[...model.fields.values()].map((f) => `${f.sourceName}: item.${f.name}`).join(',\n')}}))
|
|
197
|
+
})
|
|
198
198
|
|
|
199
199
|
for (const item of items) {
|
|
200
|
-
|
|
201
|
-
this.data.set(newItem.id, newItem)
|
|
200
|
+
this.data.set(item.id, item)
|
|
202
201
|
${isGenerated ? `if (item.id > this.currentMaxId) { this.currentMaxId = item.id }` : ''}
|
|
203
|
-
${uniqueStringFields.map((f) => `this.uniqueIds.${f.name}.set(
|
|
204
|
-
|
|
205
|
-
result.push(newItem)
|
|
202
|
+
${uniqueStringFields.map((f) => `this.uniqueIds.${f.name}.set(item.${f.name}, item)`).join('\n')}
|
|
206
203
|
}
|
|
207
204
|
|
|
208
|
-
return
|
|
205
|
+
return items
|
|
209
206
|
}
|
|
210
207
|
|
|
211
208
|
public async update(item: Partial<${model.typeName}> & {
|
|
@@ -303,7 +300,9 @@ export class ${meta.data.repositoryClassName} implements Repository<
|
|
|
303
300
|
/**
|
|
304
301
|
* Utility function that converts a given Database object to a TypeScript model instance
|
|
305
302
|
*/
|
|
306
|
-
private ${decoder}(item:
|
|
303
|
+
private ${decoder}(item: Pick<DbType, ${[...model.fields.values()]
|
|
304
|
+
.map((f) => `'${f.sourceName}'`)
|
|
305
|
+
.join(' | ')}>): ${model.typeName} {
|
|
307
306
|
return ${meta.types.zodDecoderFnName}.parse({
|
|
308
307
|
${[...model.fields.values()].map((f) => `${f.name}: item.${f.sourceName}`).join(',\n')}
|
|
309
308
|
})
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@postxl/generator",
|
|
3
|
-
"version": "0.6.
|
|
3
|
+
"version": "0.6.6",
|
|
4
4
|
"main": "./dist/generator.js",
|
|
5
5
|
"typings": "./dist/generator.d.ts",
|
|
6
6
|
"bin": {
|
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
"prettier": "^2.8.7",
|
|
22
22
|
"remeda": "1.9.4",
|
|
23
23
|
"zod": "3.21.4",
|
|
24
|
-
"@postxl/lock": "0.1
|
|
24
|
+
"@postxl/lock": "0.2.1"
|
|
25
25
|
},
|
|
26
26
|
"devDependencies": {
|
|
27
27
|
"@prisma/client": "4.12.0",
|