108 lines
4.2 KiB
SQL
108 lines
4.2 KiB
SQL
-- CreateEnum
|
|
CREATE TYPE "TaskStatus" AS ENUM ('TODO', 'IN_PROGRESS', 'INTERNAL_REVIEW', 'CLIENT_REVIEW', 'CHANGES', 'DONE');
|
|
|
|
-- CreateEnum
|
|
CREATE TYPE "TaskType" AS ENUM ('TRACK', 'ROTO', 'KEY', 'COMP', 'FX', 'LIGHTING', 'RENDER', 'ANIMATION', 'MODEL', 'TEXTURE', 'RIG', 'LOOKDEV', 'GENERAL');
|
|
|
|
-- AlterEnum
|
|
-- This migration adds more than one value to an enum.
|
|
-- With PostgreSQL versions 11 and earlier, this is not possible
|
|
-- in a single migration. This can be worked around by creating
|
|
-- multiple migrations, each migration adding only one value to
|
|
-- the enum.
|
|
|
|
|
|
ALTER TYPE "NotificationType" ADD VALUE 'TASK_ASSIGNED';
|
|
ALTER TYPE "NotificationType" ADD VALUE 'TASK_OVERDUE';
|
|
ALTER TYPE "NotificationType" ADD VALUE 'TASK_APPROVED';
|
|
ALTER TYPE "NotificationType" ADD VALUE 'TASK_CHANGES_REQUESTED';
|
|
ALTER TYPE "NotificationType" ADD VALUE 'TASK_READY_FOR_REVIEW';
|
|
|
|
-- DropForeignKey
|
|
ALTER TABLE "projects" DROP CONSTRAINT "projects_clientId_fkey";
|
|
|
|
-- DropIndex
|
|
DROP INDEX "versions_shotId_versionNumber_key";
|
|
|
|
-- AlterTable
|
|
ALTER TABLE "projects" ALTER COLUMN "clientId" DROP NOT NULL;
|
|
|
|
-- AlterTable
|
|
ALTER TABLE "versions" ADD COLUMN "isClientVisible" BOOLEAN NOT NULL DEFAULT false,
|
|
ADD COLUMN "sharedAt" TIMESTAMP(3),
|
|
ADD COLUMN "sharedById" TEXT,
|
|
ADD COLUMN "taskId" TEXT,
|
|
ALTER COLUMN "shotId" DROP NOT NULL;
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "assets" (
|
|
"id" TEXT NOT NULL,
|
|
"projectId" TEXT NOT NULL,
|
|
"assetCode" TEXT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"description" TEXT,
|
|
"status" "ShotStatus" NOT NULL DEFAULT 'WAITING',
|
|
"priority" "ShotPriority" NOT NULL DEFAULT 'NORMAL',
|
|
"leadId" TEXT,
|
|
"dueDate" TIMESTAMP(3),
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "assets_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "tasks" (
|
|
"id" TEXT NOT NULL,
|
|
"title" TEXT NOT NULL,
|
|
"description" TEXT,
|
|
"type" "TaskType" NOT NULL DEFAULT 'GENERAL',
|
|
"status" "TaskStatus" NOT NULL DEFAULT 'TODO',
|
|
"priority" "ShotPriority" NOT NULL DEFAULT 'NORMAL',
|
|
"dueDate" TIMESTAMP(3),
|
|
"estimatedHours" DOUBLE PRECISION,
|
|
"sortOrder" INTEGER NOT NULL DEFAULT 0,
|
|
"shotId" TEXT,
|
|
"assetId" TEXT,
|
|
"assignedArtistId" TEXT,
|
|
"createdById" TEXT NOT NULL,
|
|
"projectId" TEXT NOT NULL,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "tasks_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "assets_projectId_assetCode_key" ON "assets"("projectId", "assetCode");
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "projects" ADD CONSTRAINT "projects_clientId_fkey" FOREIGN KEY ("clientId") REFERENCES "clients"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "versions" ADD CONSTRAINT "versions_taskId_fkey" FOREIGN KEY ("taskId") REFERENCES "tasks"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "versions" ADD CONSTRAINT "versions_sharedById_fkey" FOREIGN KEY ("sharedById") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "assets" ADD CONSTRAINT "assets_projectId_fkey" FOREIGN KEY ("projectId") REFERENCES "projects"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "assets" ADD CONSTRAINT "assets_leadId_fkey" FOREIGN KEY ("leadId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "tasks" ADD CONSTRAINT "tasks_shotId_fkey" FOREIGN KEY ("shotId") REFERENCES "shots"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "tasks" ADD CONSTRAINT "tasks_assetId_fkey" FOREIGN KEY ("assetId") REFERENCES "assets"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "tasks" ADD CONSTRAINT "tasks_assignedArtistId_fkey" FOREIGN KEY ("assignedArtistId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "tasks" ADD CONSTRAINT "tasks_createdById_fkey" FOREIGN KEY ("createdById") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "tasks" ADD CONSTRAINT "tasks_projectId_fkey" FOREIGN KEY ("projectId") REFERENCES "projects"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|