feat: modernize report scheduling UI and date inputs

This commit is contained in:
Esdras Renan 2025-11-10 11:05:53 -03:00
parent 8cc513c532
commit 616fe42e10
10 changed files with 384 additions and 60 deletions

View file

@ -0,0 +1,50 @@
-- CreateTable
CREATE TABLE "ReportExportSchedule" (
"id" TEXT NOT NULL PRIMARY KEY,
"tenantId" TEXT NOT NULL,
"name" TEXT NOT NULL,
"reportKeys" JSONB NOT NULL,
"range" TEXT NOT NULL DEFAULT '30d',
"companyId" TEXT,
"companyName" TEXT,
"format" TEXT NOT NULL DEFAULT 'xlsx',
"frequency" TEXT NOT NULL,
"dayOfWeek" INTEGER,
"dayOfMonth" INTEGER,
"hour" INTEGER NOT NULL DEFAULT 8,
"minute" INTEGER NOT NULL DEFAULT 0,
"timezone" TEXT NOT NULL DEFAULT 'America/Sao_Paulo',
"recipients" JSONB NOT NULL,
"status" TEXT NOT NULL DEFAULT 'ACTIVE',
"lastRunAt" DATETIME,
"nextRunAt" DATETIME,
"createdBy" TEXT NOT NULL,
"updatedBy" TEXT,
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
"updatedAt" DATETIME NOT NULL
);
-- CreateTable
CREATE TABLE "ReportExportRun" (
"id" TEXT NOT NULL PRIMARY KEY,
"tenantId" TEXT NOT NULL,
"scheduleId" TEXT NOT NULL,
"status" TEXT NOT NULL DEFAULT 'PENDING',
"startedAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
"completedAt" DATETIME,
"error" TEXT,
"artifacts" JSONB,
CONSTRAINT "ReportExportRun_scheduleId_fkey" FOREIGN KEY ("scheduleId") REFERENCES "ReportExportSchedule" ("id") ON DELETE CASCADE ON UPDATE CASCADE
);
-- CreateIndex
CREATE INDEX "ReportExportSchedule_tenantId_status_idx" ON "ReportExportSchedule"("tenantId", "status");
-- CreateIndex
CREATE INDEX "ReportExportSchedule_tenantId_nextRunAt_idx" ON "ReportExportSchedule"("tenantId", "nextRunAt");
-- CreateIndex
CREATE INDEX "ReportExportRun_tenantId_status_idx" ON "ReportExportRun"("tenantId", "status");
-- CreateIndex
CREATE INDEX "ReportExportRun_tenantId_scheduleId_idx" ON "ReportExportRun"("tenantId", "scheduleId");