mirror of
https://github.com/mfts/papermark.git
synced 2025-12-20 01:03:24 +08:00
402 lines
9.5 KiB
TypeScript
402 lines
9.5 KiB
TypeScript
import {
|
|
Agreement,
|
|
CustomField,
|
|
DataroomDocument,
|
|
DataroomFolder,
|
|
Document,
|
|
DocumentVersion,
|
|
Link,
|
|
PermissionGroupAccessControls,
|
|
User as PrismaUser,
|
|
View,
|
|
ViewerGroupAccessControls,
|
|
} from "@prisma/client";
|
|
import { User as NextAuthUser } from "next-auth";
|
|
import { z } from "zod";
|
|
|
|
export type CustomUser = NextAuthUser & PrismaUser;
|
|
|
|
export interface CreateUserEmailProps {
|
|
user: {
|
|
name: string | null | undefined;
|
|
email: string | null | undefined;
|
|
};
|
|
}
|
|
|
|
export interface DocumentWithLinksAndLinkCountAndViewCount extends Document {
|
|
_count: {
|
|
links: number;
|
|
views: number;
|
|
versions: number;
|
|
datarooms: number;
|
|
};
|
|
links: Link[];
|
|
folder: {
|
|
name: string;
|
|
path: string;
|
|
};
|
|
folderList: string[];
|
|
}
|
|
|
|
export interface DocumentWithVersion extends Document {
|
|
versions: DocumentVersion[];
|
|
folder: {
|
|
name: string;
|
|
path: string;
|
|
};
|
|
datarooms: {
|
|
dataroom: {
|
|
id: string;
|
|
name: string;
|
|
};
|
|
folder: {
|
|
id: string;
|
|
name: string;
|
|
path: string;
|
|
};
|
|
}[];
|
|
hasPageLinks: boolean;
|
|
}
|
|
|
|
export interface LinkWithViews extends Link {
|
|
_count: {
|
|
views: number;
|
|
};
|
|
views: View[];
|
|
feedback: { id: true; data: { question: string; type: string } } | null;
|
|
customFields: CustomField[];
|
|
tags: TagProps[];
|
|
uploadFolderName: string | undefined;
|
|
}
|
|
|
|
export interface LinkWithDocument extends Link {
|
|
document: Document & {
|
|
versions: {
|
|
id: string;
|
|
versionNumber: number;
|
|
type: string;
|
|
hasPages: boolean;
|
|
file: string;
|
|
isVertical: boolean;
|
|
}[];
|
|
team: {
|
|
plan: string;
|
|
} | null;
|
|
};
|
|
feedback: {
|
|
id: string;
|
|
data: {
|
|
question: string;
|
|
type: string;
|
|
};
|
|
} | null;
|
|
agreement: Agreement | null;
|
|
customFields: CustomField[];
|
|
}
|
|
|
|
export interface LinkWithDataroomDocument extends Link {
|
|
dataroomDocument: DataroomDocument & {
|
|
document: Document & {
|
|
versions: {
|
|
id: string;
|
|
versionNumber: number;
|
|
type: string;
|
|
hasPages: boolean;
|
|
file: string;
|
|
isVertical: boolean;
|
|
}[];
|
|
};
|
|
};
|
|
feedback: {
|
|
id: string;
|
|
data: {
|
|
question: string;
|
|
type: string;
|
|
};
|
|
} | null;
|
|
agreement: Agreement | null;
|
|
customFields: CustomField[];
|
|
teamId: string;
|
|
team: {
|
|
plan: string;
|
|
};
|
|
}
|
|
|
|
export interface LinkWithDataroom extends Link {
|
|
dataroom: {
|
|
id: string;
|
|
name: string;
|
|
teamId: string;
|
|
documents: {
|
|
id: string;
|
|
folderId: string | null;
|
|
updatedAt: Date;
|
|
orderIndex: number | null;
|
|
hierarchicalIndex: string | null;
|
|
document: {
|
|
id: string;
|
|
name: string;
|
|
versions: {
|
|
id: string;
|
|
versionNumber: number;
|
|
type: string;
|
|
hasPages: boolean;
|
|
file: string;
|
|
isVertical: boolean;
|
|
updatedAt: Date;
|
|
}[];
|
|
};
|
|
}[];
|
|
folders: DataroomFolder[];
|
|
lastUpdatedAt: Date;
|
|
createdAt: Date;
|
|
};
|
|
group?: {
|
|
accessControls: ViewerGroupAccessControls[];
|
|
};
|
|
accessControls?:
|
|
| ViewerGroupAccessControls[]
|
|
| PermissionGroupAccessControls[];
|
|
agreement: Agreement | null;
|
|
customFields: CustomField[];
|
|
enableIndexFile: boolean;
|
|
}
|
|
|
|
export interface Geo {
|
|
city?: string | undefined;
|
|
country?: string | undefined;
|
|
region?: string | undefined;
|
|
latitude?: string | undefined;
|
|
longitude?: string | undefined;
|
|
}
|
|
|
|
// Custom Domain Types
|
|
|
|
export type DomainVerificationStatusProps =
|
|
| "Valid Configuration"
|
|
| "Invalid Configuration"
|
|
| "Pending Verification"
|
|
| "Domain Not Found"
|
|
| "Unknown Error"
|
|
| "Conflicting DNS Records";
|
|
|
|
// From https://vercel.com/docs/rest-api/endpoints#get-a-project-domain
|
|
export interface DomainResponse {
|
|
name: string;
|
|
apexName: string;
|
|
projectId: string;
|
|
redirect?: string | null;
|
|
redirectStatusCode?: (307 | 301 | 302 | 308) | null;
|
|
gitBranch?: string | null;
|
|
updatedAt?: number;
|
|
createdAt?: number;
|
|
/** `true` if the domain is verified for use with the project. If `false` it will not be used as an alias on this project until the challenge in `verification` is completed. */
|
|
verified: boolean;
|
|
/** A list of verification challenges, one of which must be completed to verify the domain for use on the project. After the challenge is complete `POST /projects/:idOrName/domains/:domain/verify` to verify the domain. Possible challenges: - If `verification.type = TXT` the `verification.domain` will be checked for a TXT record matching `verification.value`. */
|
|
verification: {
|
|
type: string;
|
|
domain: string;
|
|
value: string;
|
|
reason: string;
|
|
}[];
|
|
}
|
|
|
|
// From https://vercel.com/docs/rest-api/endpoints#get-a-domain-s-configuration
|
|
export interface DomainConfigResponse {
|
|
/** How we see the domain's configuration. - `CNAME`: Domain has a CNAME pointing to Vercel. - `A`: Domain's A record is resolving to Vercel. - `http`: Domain is resolving to Vercel but may be behind a Proxy. - `null`: Domain is not resolving to Vercel. */
|
|
configuredBy?: ("CNAME" | "A" | "http") | null;
|
|
/** Which challenge types the domain can use for issuing certs. */
|
|
acceptedChallenges?: ("dns-01" | "http-01")[];
|
|
/** Whether or not the domain is configured AND we can automatically generate a TLS certificate. */
|
|
misconfigured: boolean;
|
|
/** conflicts */
|
|
conflicts: {
|
|
name: string;
|
|
type: string;
|
|
value: string;
|
|
}[];
|
|
}
|
|
|
|
// From https://vercel.com/docs/rest-api/endpoints#verify-project-domain
|
|
export interface DomainVerificationResponse {
|
|
name: string;
|
|
apexName: string;
|
|
projectId: string;
|
|
redirect?: string | null;
|
|
redirectStatusCode?: (307 | 301 | 302 | 308) | null;
|
|
gitBranch?: string | null;
|
|
updatedAt?: number;
|
|
createdAt?: number;
|
|
/** `true` if the domain is verified for use with the project. If `false` it will not be used as an alias on this project until the challenge in `verification` is completed. */
|
|
verified: boolean;
|
|
/** A list of verification challenges, one of which must be completed to verify the domain for use on the project. After the challenge is complete `POST /projects/:idOrName/domains/:domain/verify` to verify the domain. Possible challenges: - If `verification.type = TXT` the `verification.domain` will be checked for a TXT record matching `verification.value`. */
|
|
verification?: {
|
|
type: string;
|
|
domain: string;
|
|
value: string;
|
|
reason: string;
|
|
}[];
|
|
}
|
|
|
|
export type AnalyticsEvents =
|
|
| {
|
|
event: "User Signed Up";
|
|
userId: string;
|
|
email: string | null | undefined;
|
|
}
|
|
| {
|
|
event: "Document Added";
|
|
documentId: string;
|
|
name: string;
|
|
fileSize: string | null | undefined;
|
|
path: string | null | undefined;
|
|
}
|
|
| {
|
|
event: "Link Added";
|
|
linkId: string;
|
|
documentId: string;
|
|
customDomain: string | null | undefined;
|
|
}
|
|
| { event: "User Upgraded"; email: string | null | undefined }
|
|
| {
|
|
event: "User Signed In";
|
|
email: string | null | undefined;
|
|
}
|
|
| {
|
|
event: "Link Viewed";
|
|
documentId: string;
|
|
linkId: string;
|
|
viewerId: string;
|
|
viewerEmail: string | null | undefined;
|
|
}
|
|
| {
|
|
event: "Domain Added";
|
|
slug: string;
|
|
}
|
|
| {
|
|
event: "Domain Verified";
|
|
slug: string;
|
|
}
|
|
| {
|
|
event: "Domain Deleted";
|
|
slug: string;
|
|
}
|
|
| {
|
|
event: "Team Member Invitation Accepted";
|
|
teamId: string;
|
|
}
|
|
| {
|
|
event: "Stripe Checkout Clicked";
|
|
teamId: string;
|
|
priceId: string;
|
|
}
|
|
| {
|
|
event: "Stripe Billing Portal Clicked";
|
|
teamId: string;
|
|
action?: string;
|
|
}
|
|
| {
|
|
event: "User Sign In Attempted";
|
|
email: string | undefined;
|
|
userId: string;
|
|
};
|
|
|
|
export interface Team {
|
|
id: string;
|
|
name?: string;
|
|
logo?: React.ElementType;
|
|
plan?: string;
|
|
createdAt?: Date;
|
|
enableExcelAdvancedMode?: boolean;
|
|
replicateDataroomFolders?: boolean;
|
|
}
|
|
|
|
export interface TeamDetail {
|
|
id: string;
|
|
name: string;
|
|
users: {
|
|
role: "ADMIN" | "MANAGER" | "MEMBER";
|
|
status: "ACTIVE" | "BLOCKED_TRIAL_EXPIRED";
|
|
teamId: string;
|
|
userId: string;
|
|
user: {
|
|
email: string;
|
|
name: string;
|
|
};
|
|
}[];
|
|
documents: {
|
|
owner: {
|
|
name: string;
|
|
id: string;
|
|
};
|
|
}[];
|
|
}
|
|
|
|
export const WatermarkConfigSchema = z.object({
|
|
text: z.string().min(1, "Text is required."),
|
|
isTiled: z.boolean(),
|
|
position: z.enum([
|
|
"top-left",
|
|
"top-center",
|
|
"top-right",
|
|
"middle-left",
|
|
"middle-center",
|
|
"middle-right",
|
|
"bottom-left",
|
|
"bottom-center",
|
|
"bottom-right",
|
|
]),
|
|
rotation: z.union([
|
|
z.literal(0),
|
|
z.literal(30),
|
|
z.literal(45),
|
|
z.literal(90),
|
|
z.literal(180),
|
|
]),
|
|
color: z.string().refine((val) => /^#([0-9A-F]{3}){1,2}$/i.test(val), {
|
|
message: "Invalid color format. Use HEX format like #RRGGBB.",
|
|
}),
|
|
fontSize: z.number().min(1, "Font size must be greater than 0."),
|
|
opacity: z.number().min(0).max(1, "Opacity must be between 0 and 1."),
|
|
});
|
|
|
|
export type WatermarkConfig = z.infer<typeof WatermarkConfigSchema>;
|
|
|
|
export type NotionTheme = "light" | "dark";
|
|
|
|
export type BasePlan =
|
|
| "free"
|
|
| "pro"
|
|
| "business"
|
|
| "datarooms"
|
|
| "datarooms-plus"
|
|
| "enterprise";
|
|
|
|
export const tagColors = [
|
|
"red",
|
|
"yellow",
|
|
"green",
|
|
"blue",
|
|
"purple",
|
|
"pink",
|
|
"slate",
|
|
"fuchsia",
|
|
] as const;
|
|
|
|
export type TagColorProps = (typeof tagColors)[number];
|
|
|
|
export interface TagsWithTotalCount {
|
|
tags: TagProps[];
|
|
totalCount: number;
|
|
}
|
|
|
|
export interface TagProps {
|
|
id: string;
|
|
name: string;
|
|
description: string | null;
|
|
color: TagColorProps | string;
|
|
_count?: {
|
|
items: number;
|
|
};
|
|
}
|