You've already forked obsidian-visualiser
Add character selection using campaign visibility and player characters in campaign
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
import useDatabase from '~/composables/useDatabase';
|
||||
import { characterTable } from '~/db/schema';
|
||||
import { campaignCharactersTable, campaignMembersTable, campaignTable, characterAbilitiesTable, characterChoicesTable, characterLevelingTable, characterTable, characterTrainingTable, usersTable } from '~/db/schema';
|
||||
import { group } from '#shared/general.util';
|
||||
import type { Character, CharacterVariables, Level, MainStat, TrainingLevel } from '~/types/character';
|
||||
import type { Character, MainStat, TrainingLevel } from '~/types/character';
|
||||
import { and, eq, exists, getTableColumns, isNotNull, or, sql } from 'drizzle-orm';
|
||||
|
||||
export default defineEventHandler(async (e) => {
|
||||
const id = getRouterParam(e, "id");
|
||||
@@ -21,6 +22,7 @@ export default defineEventHandler(async (e) => {
|
||||
}
|
||||
|
||||
const db = useDatabase();
|
||||
|
||||
const character = db.query.characterTable.findFirst({
|
||||
with: {
|
||||
abilities: true,
|
||||
@@ -29,9 +31,23 @@ export default defineEventHandler(async (e) => {
|
||||
choices: true,
|
||||
user: {
|
||||
columns: { username: true }
|
||||
},
|
||||
campaign: {
|
||||
columns: { character: false, id: false, },
|
||||
with: {
|
||||
campaign: {
|
||||
columns: { owner: true, },
|
||||
with: {
|
||||
members: { columns: { user: true } }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
where: (character, { eq, and }) => and(eq(character.id, parseInt(id, 10)), eq(characterTable.owner, session.user!.id)),
|
||||
where: and(eq(characterTable.id, parseInt(id, 10)), or(eq(characterTable.visibility, 'public'), eq(characterTable.owner, session.user!.id), exists(db.select({ id: sql`NULL` }).from(campaignCharactersTable)
|
||||
.leftJoin(campaignTable, eq(campaignCharactersTable.id, campaignTable.id))
|
||||
.leftJoin(campaignMembersTable, and(eq(campaignMembersTable.id, campaignTable.id), eq(campaignMembersTable.user, session.user.id)))
|
||||
.where(and(eq(campaignCharactersTable.character, parseInt(id, 10)), or(eq(campaignTable.owner, session.user.id), isNotNull(campaignMembersTable.user))))))),
|
||||
}).sync();
|
||||
|
||||
if(character !== undefined)
|
||||
|
||||
Reference in New Issue
Block a user