diff --git a/prisma/migrations/20230402154437_added_manuacturer_and_devicetype/migration.sql b/prisma/migrations/20230402154437_added_manuacturer_and_devicetype/migration.sql new file mode 100644 index 0000000..36fd6f1 --- /dev/null +++ b/prisma/migrations/20230402154437_added_manuacturer_and_devicetype/migration.sql @@ -0,0 +1,85 @@ +-- CreateTable +CREATE TABLE "Example" ( + "id" TEXT NOT NULL PRIMARY KEY, + "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updatedAt" DATETIME NOT NULL +); + +-- CreateTable +CREATE TABLE "Account" ( + "id" TEXT NOT NULL PRIMARY KEY, + "userId" TEXT NOT NULL, + "type" TEXT NOT NULL, + "provider" TEXT NOT NULL, + "providerAccountId" TEXT NOT NULL, + "refresh_token" TEXT, + "access_token" TEXT, + "expires_at" INTEGER, + "token_type" TEXT, + "scope" TEXT, + "id_token" TEXT, + "session_state" TEXT, + CONSTRAINT "Account_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE +); + +-- CreateTable +CREATE TABLE "Session" ( + "id" TEXT NOT NULL PRIMARY KEY, + "sessionToken" TEXT NOT NULL, + "userId" TEXT NOT NULL, + "expires" DATETIME NOT NULL, + CONSTRAINT "Session_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE +); + +-- CreateTable +CREATE TABLE "User" ( + "id" TEXT NOT NULL PRIMARY KEY, + "name" TEXT, + "email" TEXT, + "emailVerified" DATETIME, + "image" TEXT +); + +-- CreateTable +CREATE TABLE "VerificationToken" ( + "identifier" TEXT NOT NULL, + "token" TEXT NOT NULL, + "expires" DATETIME NOT NULL +); + +-- CreateTable +CREATE TABLE "Manufacturer" ( + "id" TEXT NOT NULL PRIMARY KEY, + "name" TEXT NOT NULL +); + +-- CreateTable +CREATE TABLE "DeviceTypes" ( + "id" TEXT NOT NULL PRIMARY KEY, + "name" TEXT NOT NULL, + "manufacturerId" TEXT NOT NULL, + CONSTRAINT "DeviceTypes_manufacturerId_fkey" FOREIGN KEY ("manufacturerId") REFERENCES "Manufacturer" ("id") ON DELETE RESTRICT ON UPDATE CASCADE +); + +-- CreateTable +CREATE TABLE "Device" ( + "id" TEXT NOT NULL PRIMARY KEY, + "name" TEXT NOT NULL, + "deviceTypeId" TEXT NOT NULL, + CONSTRAINT "Device_deviceTypeId_fkey" FOREIGN KEY ("deviceTypeId") REFERENCES "DeviceTypes" ("id") ON DELETE RESTRICT ON UPDATE CASCADE +); + +-- CreateIndex +CREATE UNIQUE INDEX "Account_provider_providerAccountId_key" ON "Account"("provider", "providerAccountId"); + +-- CreateIndex +CREATE UNIQUE INDEX "Session_sessionToken_key" ON "Session"("sessionToken"); + +-- CreateIndex +CREATE UNIQUE INDEX "User_email_key" ON "User"("email"); + +-- CreateIndex +CREATE UNIQUE INDEX "VerificationToken_token_key" ON "VerificationToken"("token"); + +-- CreateIndex +CREATE UNIQUE INDEX "VerificationToken_identifier_token_key" ON "VerificationToken"("identifier", "token"); diff --git a/prisma/migrations/migration_lock.toml b/prisma/migrations/migration_lock.toml new file mode 100644 index 0000000..e5e5c47 --- /dev/null +++ b/prisma/migrations/migration_lock.toml @@ -0,0 +1,3 @@ +# Please do not edit this file manually +# It should be added in your version-control system (i.e. Git) +provider = "sqlite" \ No newline at end of file diff --git a/prisma/schema.prisma b/prisma/schema.prisma index d06d0da..53b1470 100644 --- a/prisma/schema.prisma +++ b/prisma/schema.prisma @@ -65,7 +65,23 @@ model VerificationToken { @@unique([identifier, token]) } +model Manufacturer { + id String @id @default(cuid()) + name String + deviceTypes DeviceTypes[] +} + +model DeviceTypes { + id String @id @default(cuid()) + name String + manufacturerId String + manufacturer Manufacturer @relation(fields: [manufacturerId], references: [id]) + devices Device[] +} + model Device { id String @id @default(cuid()) name String + deviceTypeId String + deviceType DeviceTypes @relation(fields: [deviceTypeId], references: [id]) } diff --git a/src/components/Navbar.tsx b/src/components/Navbar.tsx new file mode 100644 index 0000000..1854a34 --- /dev/null +++ b/src/components/Navbar.tsx @@ -0,0 +1,27 @@ +import { signIn, signOut } from "next-auth/react"; + +const Navbar: React.FC = (props) => { + const sessionData = props.sessionData + return ( +
+
+{device.name}
+- {sessionData && Logged in as {sessionData.user?.name}} - {secretMessage && - {secretMessage}} -
-{device.name}
-