add schema for box and item
add mobile version for datatable
This commit is contained in:
69
prisma/migrations/20260225031506_box_and_item/migration.sql
Normal file
69
prisma/migrations/20260225031506_box_and_item/migration.sql
Normal file
@@ -0,0 +1,69 @@
|
||||
-- CreateTable
|
||||
CREATE TABLE "box" (
|
||||
"id" TEXT NOT NULL,
|
||||
"houseId" TEXT,
|
||||
"icon" TEXT NOT NULL,
|
||||
"color" TEXT NOT NULL,
|
||||
"name" TEXT NOT NULL,
|
||||
"description" TEXT,
|
||||
"tags" TEXT[] DEFAULT ARRAY[]::TEXT[],
|
||||
"createrId" TEXT NOT NULL,
|
||||
"createdAt" TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
"updatedAt" TIMESTAMPTZ NOT NULL,
|
||||
"deletedAt" TIMESTAMP(3),
|
||||
"isPrivate" BOOLEAN NOT NULL DEFAULT false,
|
||||
|
||||
CONSTRAINT "box_pkey" PRIMARY KEY ("id")
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "item" (
|
||||
"id" TEXT NOT NULL,
|
||||
"createrId" TEXT NOT NULL,
|
||||
"boxId" TEXT,
|
||||
"image" TEXT NOT NULL,
|
||||
"name" TEXT NOT NULL,
|
||||
"description" TEXT,
|
||||
"price" TEXT,
|
||||
"tags" TEXT[] DEFAULT ARRAY[]::TEXT[],
|
||||
"quantity" INTEGER NOT NULL,
|
||||
"expiresAt" TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
"createdAt" TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
"updatedAt" TIMESTAMPTZ NOT NULL,
|
||||
"deletedAt" TIMESTAMP(3),
|
||||
|
||||
CONSTRAINT "item_pkey" PRIMARY KEY ("id")
|
||||
);
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "box_houseId_idx" ON "box"("houseId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "box_createrId_idx" ON "box"("createrId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "box_isPrivate_idx" ON "box"("isPrivate");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "box_tags_idx" ON "box"("tags");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "item_createrId_idx" ON "item"("createrId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "item_boxId_idx" ON "item"("boxId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "item_tags_idx" ON "item"("tags");
|
||||
|
||||
-- AddForeignKey
|
||||
ALTER TABLE "box" ADD CONSTRAINT "box_houseId_fkey" FOREIGN KEY ("houseId") REFERENCES "house"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|
||||
|
||||
-- AddForeignKey
|
||||
ALTER TABLE "box" ADD CONSTRAINT "box_createrId_fkey" FOREIGN KEY ("createrId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
||||
|
||||
-- AddForeignKey
|
||||
ALTER TABLE "item" ADD CONSTRAINT "item_createrId_fkey" FOREIGN KEY ("createrId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
||||
|
||||
-- AddForeignKey
|
||||
ALTER TABLE "item" ADD CONSTRAINT "item_boxId_fkey" FOREIGN KEY ("boxId") REFERENCES "box"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|
||||
@@ -9,44 +9,46 @@ datasource db {
|
||||
}
|
||||
|
||||
model User {
|
||||
id String @id @default(uuid())
|
||||
name String
|
||||
email String
|
||||
emailVerified Boolean @default(false)
|
||||
image String?
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
sessions Session[]
|
||||
accounts Account[]
|
||||
audit Audit[]
|
||||
notification Notification[]
|
||||
id String @id @default(uuid())
|
||||
name String
|
||||
email String
|
||||
emailVerified Boolean @default(false)
|
||||
image String?
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
sessions Session[]
|
||||
accounts Account[]
|
||||
audit Audit[]
|
||||
notification Notification[]
|
||||
|
||||
role String?
|
||||
banned Boolean? @default(false)
|
||||
banReason String?
|
||||
banExpires DateTime?
|
||||
role String?
|
||||
banned Boolean? @default(false)
|
||||
banReason String?
|
||||
banExpires DateTime?
|
||||
|
||||
members Member[]
|
||||
invitations Invitation[]
|
||||
members Member[]
|
||||
invitations Invitation[]
|
||||
boxes Box[]
|
||||
items Item[]
|
||||
|
||||
@@unique([email])
|
||||
@@map("user")
|
||||
}
|
||||
|
||||
model Session {
|
||||
id String @id @default(uuid())
|
||||
expiresAt DateTime @db.Timestamptz
|
||||
token String
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
ipAddress String?
|
||||
userAgent String?
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
id String @id @default(uuid())
|
||||
expiresAt DateTime @db.Timestamptz
|
||||
token String
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
ipAddress String?
|
||||
userAgent String?
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
|
||||
impersonatedBy String?
|
||||
impersonatedBy String?
|
||||
|
||||
activeOrganizationId String?
|
||||
activeOrganizationId String?
|
||||
|
||||
@@unique([token])
|
||||
@@index([userId])
|
||||
@@ -54,60 +56,61 @@ model Session {
|
||||
}
|
||||
|
||||
model Account {
|
||||
id String @id @default(uuid())
|
||||
accountId String
|
||||
providerId String
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
accessToken String?
|
||||
refreshToken String?
|
||||
idToken String?
|
||||
accessTokenExpiresAt DateTime?
|
||||
refreshTokenExpiresAt DateTime?
|
||||
scope String?
|
||||
password String?
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
id String @id @default(uuid())
|
||||
accountId String
|
||||
providerId String
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
accessToken String?
|
||||
refreshToken String?
|
||||
idToken String?
|
||||
accessTokenExpiresAt DateTime?
|
||||
refreshTokenExpiresAt DateTime?
|
||||
scope String?
|
||||
password String?
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
|
||||
@@index([userId])
|
||||
@@map("account")
|
||||
}
|
||||
|
||||
model Verification {
|
||||
id String @id @default(uuid())
|
||||
identifier String
|
||||
value String
|
||||
expiresAt DateTime
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
id String @id @default(uuid())
|
||||
identifier String
|
||||
value String
|
||||
expiresAt DateTime
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
|
||||
@@index([identifier])
|
||||
@@map("verification")
|
||||
}
|
||||
|
||||
model House {
|
||||
id String @id @default(uuid())
|
||||
name String
|
||||
slug String
|
||||
logo String?
|
||||
createdAt DateTime @db.Timestamptz
|
||||
metadata String?
|
||||
color String? @default("#000000")
|
||||
members Member[]
|
||||
invitations Invitation[]
|
||||
id String @id @default(uuid())
|
||||
name String
|
||||
slug String
|
||||
logo String?
|
||||
createdAt DateTime @db.Timestamptz
|
||||
metadata String?
|
||||
color String? @default("#000000")
|
||||
members Member[]
|
||||
invitations Invitation[]
|
||||
boxes Box[]
|
||||
|
||||
@@unique([slug])
|
||||
@@map("house")
|
||||
}
|
||||
|
||||
model Member {
|
||||
id String @id @default(uuid())
|
||||
organizationId String
|
||||
house House @relation(fields: [organizationId], references: [id], onDelete: Cascade)
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
role String @default("member")
|
||||
createdAt DateTime @db.Timestamptz
|
||||
id String @id @default(uuid())
|
||||
organizationId String
|
||||
house House @relation(fields: [organizationId], references: [id], onDelete: Cascade)
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
role String @default("member")
|
||||
createdAt DateTime @db.Timestamptz
|
||||
|
||||
@@index([organizationId])
|
||||
@@index([userId])
|
||||
@@ -115,16 +118,16 @@ model Member {
|
||||
}
|
||||
|
||||
model Invitation {
|
||||
id String @id @default(uuid())
|
||||
organizationId String
|
||||
house House @relation(fields: [organizationId], references: [id], onDelete: Cascade)
|
||||
email String
|
||||
role String?
|
||||
status String @default("pending")
|
||||
expiresAt DateTime @db.Timestamptz
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
inviterId String
|
||||
user User @relation(fields: [inviterId], references: [id], onDelete: Cascade)
|
||||
id String @id @default(uuid())
|
||||
organizationId String
|
||||
house House @relation(fields: [organizationId], references: [id], onDelete: Cascade)
|
||||
email String
|
||||
role String?
|
||||
status String @default("pending")
|
||||
expiresAt DateTime @db.Timestamptz
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
inviterId String
|
||||
user User @relation(fields: [inviterId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@index([organizationId])
|
||||
@@index([email])
|
||||
@@ -132,49 +135,99 @@ model Invitation {
|
||||
}
|
||||
|
||||
model Setting {
|
||||
id String @id @default(uuid())
|
||||
key String @unique
|
||||
value String
|
||||
description String
|
||||
relation String @default("admin")
|
||||
id String @id @default(uuid())
|
||||
key String @unique
|
||||
value String
|
||||
description String
|
||||
relation String @default("admin")
|
||||
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
|
||||
@@map("setting")
|
||||
}
|
||||
|
||||
model Audit {
|
||||
id String @id @default(uuid())
|
||||
userId String
|
||||
action String
|
||||
tableName String
|
||||
recordId String
|
||||
oldValue String?
|
||||
newValue String?
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
id String @id @default(uuid())
|
||||
userId String
|
||||
action String
|
||||
tableName String
|
||||
recordId String
|
||||
oldValue String?
|
||||
newValue String?
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@map("audit")
|
||||
}
|
||||
|
||||
model Notification {
|
||||
id String @id @default(uuid())
|
||||
userId String
|
||||
id String @id @default(uuid())
|
||||
userId String
|
||||
|
||||
title String
|
||||
message String
|
||||
type String @default("system")
|
||||
title String
|
||||
message String
|
||||
type String @default("system")
|
||||
|
||||
link String?
|
||||
metadata String?
|
||||
link String?
|
||||
metadata String?
|
||||
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
readAt DateTime? @db.Timestamptz
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
readAt DateTime? @db.Timestamptz
|
||||
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@index([userId, readAt])
|
||||
@@index([readAt])
|
||||
@@map("notification")
|
||||
}
|
||||
|
||||
model Box {
|
||||
id String @id @default(uuid())
|
||||
houseId String?
|
||||
icon String
|
||||
color String
|
||||
name String
|
||||
description String?
|
||||
tags String[] @default([])
|
||||
createrId String
|
||||
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
deletedAt DateTime?
|
||||
isPrivate Boolean @default(false)
|
||||
|
||||
items Item[]
|
||||
house House? @relation(fields: [houseId], references: [id], onDelete: SetNull)
|
||||
user User @relation(fields: [createrId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@index([houseId])
|
||||
@@index([createrId])
|
||||
@@index([isPrivate])
|
||||
@@index([tags])
|
||||
@@map("box")
|
||||
}
|
||||
|
||||
model Item {
|
||||
id String @id @default(uuid())
|
||||
createrId String
|
||||
boxId String?
|
||||
image String
|
||||
name String
|
||||
description String?
|
||||
price String?
|
||||
tags String[] @default([])
|
||||
quantity Int
|
||||
expiresAt DateTime @default(now()) @db.Timestamptz
|
||||
createdAt DateTime @default(now()) @db.Timestamptz
|
||||
updatedAt DateTime @updatedAt @db.Timestamptz
|
||||
deletedAt DateTime?
|
||||
|
||||
user User @relation(fields: [createrId], references: [id], onDelete: Cascade)
|
||||
box Box? @relation(fields: [boxId], references: [id], onDelete: SetNull)
|
||||
|
||||
@@index([createrId])
|
||||
@@index([boxId])
|
||||
@@index([tags])
|
||||
@@map("item")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user