70 lines
1.7 KiB
TypeScript
70 lines
1.7 KiB
TypeScript
import type { CreateVersionArgs, TypeWithVersion } from 'payload/database'
|
|
import type { PayloadRequest, TypeWithID } from 'payload/types'
|
|
|
|
import { sql } from 'drizzle-orm'
|
|
import { buildVersionCollectionFields } from 'payload/versions'
|
|
|
|
import type { PostgresAdapter } from './types.js'
|
|
|
|
import { getTableName } from './schema/getTableName.js'
|
|
import { upsertRow } from './upsertRow/index.js'
|
|
|
|
export async function createVersion<T extends TypeWithID>(
|
|
this: PostgresAdapter,
|
|
{
|
|
autosave,
|
|
collectionSlug,
|
|
parent,
|
|
req = {} as PayloadRequest,
|
|
versionData,
|
|
}: CreateVersionArgs<T>,
|
|
) {
|
|
const db = this.sessions[req.transactionID]?.db || this.drizzle
|
|
const collection = this.payload.collections[collectionSlug].config
|
|
const tableName = getTableName({
|
|
adapter: this,
|
|
config: collection,
|
|
versions: true,
|
|
})
|
|
|
|
const result = await upsertRow<TypeWithVersion<T>>({
|
|
adapter: this,
|
|
data: {
|
|
autosave,
|
|
latest: true,
|
|
parent,
|
|
version: versionData,
|
|
},
|
|
db,
|
|
fields: buildVersionCollectionFields(collection),
|
|
operation: 'create',
|
|
req,
|
|
tableName,
|
|
})
|
|
|
|
const table = this.tables[tableName]
|
|
const relationshipsTable =
|
|
this.tables[
|
|
getTableName({
|
|
adapter: this,
|
|
config: collection,
|
|
relationships: true,
|
|
versions: true,
|
|
})
|
|
]
|
|
|
|
if (collection.versions.drafts) {
|
|
await db.execute(sql`
|
|
UPDATE ${table}
|
|
SET latest = false
|
|
FROM ${relationshipsTable}
|
|
WHERE ${table.id} = ${relationshipsTable.parent}
|
|
AND ${relationshipsTable.path} = ${'parent'}
|
|
AND ${relationshipsTable[`${collectionSlug}ID`]} = ${parent}
|
|
AND ${table.id} != ${result.id};
|
|
`)
|
|
}
|
|
|
|
return result
|
|
}
|