feat: add Weekly Check-in feature with models, UI components, and session management for enhanced team collaboration
All checks were successful
Deploy with Docker Compose / deploy (push) Successful in 6m24s
All checks were successful
Deploy with Docker Compose / deploy (push) Successful in 6m24s
This commit is contained in:
@@ -0,0 +1,103 @@
|
||||
-- CreateEnum
|
||||
CREATE TABLE "WeeklyCheckInCategory" (
|
||||
"value" TEXT NOT NULL PRIMARY KEY
|
||||
);
|
||||
|
||||
-- CreateEnum
|
||||
CREATE TABLE "Emotion" (
|
||||
"value" TEXT NOT NULL PRIMARY KEY
|
||||
);
|
||||
|
||||
-- InsertEnumValues
|
||||
INSERT INTO "WeeklyCheckInCategory" ("value") VALUES ('WENT_WELL');
|
||||
INSERT INTO "WeeklyCheckInCategory" ("value") VALUES ('WENT_WRONG');
|
||||
INSERT INTO "WeeklyCheckInCategory" ("value") VALUES ('CURRENT_FOCUS');
|
||||
INSERT INTO "WeeklyCheckInCategory" ("value") VALUES ('NEXT_FOCUS');
|
||||
|
||||
-- InsertEnumValues
|
||||
INSERT INTO "Emotion" ("value") VALUES ('PRIDE');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('JOY');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('SATISFACTION');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('GRATITUDE');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('CONFIDENCE');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('FRUSTRATION');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('WORRY');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('DISAPPOINTMENT');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('EXCITEMENT');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('ANTICIPATION');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('DETERMINATION');
|
||||
INSERT INTO "Emotion" ("value") VALUES ('NONE');
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "WeeklyCheckInSession" (
|
||||
"id" TEXT NOT NULL PRIMARY KEY,
|
||||
"title" TEXT NOT NULL,
|
||||
"participant" TEXT NOT NULL,
|
||||
"date" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
"userId" TEXT NOT NULL,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
"updatedAt" DATETIME NOT NULL,
|
||||
CONSTRAINT "WeeklyCheckInSession_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "WeeklyCheckInItem" (
|
||||
"id" TEXT NOT NULL PRIMARY KEY,
|
||||
"content" TEXT NOT NULL,
|
||||
"category" TEXT NOT NULL,
|
||||
"emotion" TEXT NOT NULL DEFAULT 'NONE',
|
||||
"order" INTEGER NOT NULL DEFAULT 0,
|
||||
"sessionId" TEXT NOT NULL,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
"updatedAt" DATETIME NOT NULL,
|
||||
CONSTRAINT "WeeklyCheckInItem_sessionId_fkey" FOREIGN KEY ("sessionId") REFERENCES "WeeklyCheckInSession" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
CONSTRAINT "WeeklyCheckInItem_category_fkey" FOREIGN KEY ("category") REFERENCES "WeeklyCheckInCategory" ("value") ON DELETE RESTRICT ON UPDATE CASCADE,
|
||||
CONSTRAINT "WeeklyCheckInItem_emotion_fkey" FOREIGN KEY ("emotion") REFERENCES "Emotion" ("value") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "WCISessionShare" (
|
||||
"id" TEXT NOT NULL PRIMARY KEY,
|
||||
"sessionId" TEXT NOT NULL,
|
||||
"userId" TEXT NOT NULL,
|
||||
"role" TEXT NOT NULL DEFAULT 'EDITOR',
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
CONSTRAINT "WCISessionShare_sessionId_fkey" FOREIGN KEY ("sessionId") REFERENCES "WeeklyCheckInSession" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
CONSTRAINT "WCISessionShare_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "WCISessionEvent" (
|
||||
"id" TEXT NOT NULL PRIMARY KEY,
|
||||
"sessionId" TEXT NOT NULL,
|
||||
"userId" TEXT NOT NULL,
|
||||
"type" TEXT NOT NULL,
|
||||
"payload" TEXT NOT NULL,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
CONSTRAINT "WCISessionEvent_sessionId_fkey" FOREIGN KEY ("sessionId") REFERENCES "WeeklyCheckInSession" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
CONSTRAINT "WCISessionEvent_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "WeeklyCheckInSession_userId_idx" ON "WeeklyCheckInSession"("userId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "WeeklyCheckInSession_date_idx" ON "WeeklyCheckInSession"("date");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "WeeklyCheckInItem_sessionId_idx" ON "WeeklyCheckInItem"("sessionId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "WeeklyCheckInItem_sessionId_category_idx" ON "WeeklyCheckInItem"("sessionId", "category");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "WCISessionShare_sessionId_idx" ON "WCISessionShare"("sessionId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "WCISessionShare_userId_idx" ON "WCISessionShare"("userId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE UNIQUE INDEX "WCISessionShare_sessionId_userId_key" ON "WCISessionShare"("sessionId", "userId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "WCISessionEvent_sessionId_createdAt_idx" ON "WCISessionEvent"("sessionId", "createdAt");
|
||||
@@ -25,6 +25,10 @@ model User {
|
||||
yearReviewSessions YearReviewSession[]
|
||||
sharedYearReviewSessions YRSessionShare[]
|
||||
yearReviewSessionEvents YRSessionEvent[]
|
||||
// Weekly Check-in relations
|
||||
weeklyCheckInSessions WeeklyCheckInSession[]
|
||||
sharedWeeklyCheckInSessions WCISessionShare[]
|
||||
weeklyCheckInSessionEvents WCISessionEvent[]
|
||||
// Teams & OKRs relations
|
||||
createdTeams Team[]
|
||||
teamMembers TeamMember[]
|
||||
@@ -365,3 +369,88 @@ model KeyResult {
|
||||
@@index([okrId])
|
||||
@@index([okrId, order])
|
||||
}
|
||||
|
||||
// ============================================
|
||||
// Weekly Check-in Workshop
|
||||
// ============================================
|
||||
|
||||
enum WeeklyCheckInCategory {
|
||||
WENT_WELL // Ce qui s'est bien passé
|
||||
WENT_WRONG // Ce qui s'est mal passé
|
||||
CURRENT_FOCUS // Les enjeux du moment (je me concentre sur ...)
|
||||
NEXT_FOCUS // Les prochains enjeux
|
||||
}
|
||||
|
||||
enum Emotion {
|
||||
PRIDE // Fierté
|
||||
JOY // Joie
|
||||
SATISFACTION // Satisfaction
|
||||
GRATITUDE // Gratitude
|
||||
CONFIDENCE // Confiance
|
||||
FRUSTRATION // Frustration
|
||||
WORRY // Inquiétude
|
||||
DISAPPOINTMENT // Déception
|
||||
EXCITEMENT // Excitement
|
||||
ANTICIPATION // Anticipation
|
||||
DETERMINATION // Détermination
|
||||
NONE // Aucune émotion
|
||||
}
|
||||
|
||||
model WeeklyCheckInSession {
|
||||
id String @id @default(cuid())
|
||||
title String
|
||||
participant String // Nom du participant
|
||||
date DateTime @default(now())
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
items WeeklyCheckInItem[]
|
||||
shares WCISessionShare[]
|
||||
events WCISessionEvent[]
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
|
||||
@@index([userId])
|
||||
@@index([date])
|
||||
}
|
||||
|
||||
model WeeklyCheckInItem {
|
||||
id String @id @default(cuid())
|
||||
content String
|
||||
category WeeklyCheckInCategory
|
||||
emotion Emotion @default(NONE)
|
||||
order Int @default(0)
|
||||
sessionId String
|
||||
session WeeklyCheckInSession @relation(fields: [sessionId], references: [id], onDelete: Cascade)
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
|
||||
@@index([sessionId])
|
||||
@@index([sessionId, category])
|
||||
}
|
||||
|
||||
model WCISessionShare {
|
||||
id String @id @default(cuid())
|
||||
sessionId String
|
||||
session WeeklyCheckInSession @relation(fields: [sessionId], references: [id], onDelete: Cascade)
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
role ShareRole @default(EDITOR)
|
||||
createdAt DateTime @default(now())
|
||||
|
||||
@@unique([sessionId, userId])
|
||||
@@index([sessionId])
|
||||
@@index([userId])
|
||||
}
|
||||
|
||||
model WCISessionEvent {
|
||||
id String @id @default(cuid())
|
||||
sessionId String
|
||||
session WeeklyCheckInSession @relation(fields: [sessionId], references: [id], onDelete: Cascade)
|
||||
userId String
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
type String // ITEM_CREATED, ITEM_UPDATED, ITEM_DELETED, etc.
|
||||
payload String // JSON payload
|
||||
createdAt DateTime @default(now())
|
||||
|
||||
@@index([sessionId, createdAt])
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user