aboutsummaryrefslogtreecommitdiffstats
path: root/packages/shared
diff options
context:
space:
mode:
Diffstat (limited to 'packages/shared')
-rw-r--r--packages/shared/types/lists.ts82
1 files changed, 65 insertions, 17 deletions
diff --git a/packages/shared/types/lists.ts b/packages/shared/types/lists.ts
index d2041907..bd6786b0 100644
--- a/packages/shared/types/lists.ts
+++ b/packages/shared/types/lists.ts
@@ -1,28 +1,76 @@
import { z } from "zod";
-export const zNewBookmarkListSchema = z.object({
- name: z
- .string()
- .min(1, "List name can't be empty")
- .max(40, "List name is at most 40 chars"),
- icon: z.string(),
- parentId: z.string().nullish(),
-});
+import { parseSearchQuery } from "../searchQueryParser";
+
+export const zNewBookmarkListSchema = z
+ .object({
+ name: z
+ .string()
+ .min(1, "List name can't be empty")
+ .max(40, "List name is at most 40 chars"),
+ icon: z.string(),
+ type: z.enum(["manual", "smart"]).optional().default("manual"),
+ query: z.string().min(1).optional(),
+ parentId: z.string().nullish(),
+ })
+ .refine((val) => val.type === "smart" || !val.query, {
+ message: "Manual lists cannot have a query",
+ path: ["query"],
+ })
+ .refine((val) => val.type === "manual" || val.query, {
+ message: "Smart lists must have a query",
+ path: ["query"],
+ })
+ .refine(
+ (val) => !val.query || parseSearchQuery(val.query).result === "full",
+ {
+ message: "Smart search query is not valid",
+ path: ["query"],
+ },
+ )
+ .refine((val) => !val.query || parseSearchQuery(val.query).text.length == 0, {
+ message:
+ "Smart lists cannot have unqualified terms (aka full text search terms) in the query",
+ path: ["query"],
+ });
export const zBookmarkListSchema = z.object({
id: z.string(),
name: z.string(),
icon: z.string(),
parentId: z.string().nullable(),
+ type: z.enum(["manual", "smart"]).default("manual"),
+ query: z.string().nullish(),
});
-export const zBookmarkListWithBookmarksSchema = zBookmarkListSchema.merge(
- z.object({
- bookmarks: z.array(z.string()),
- }),
-);
-
export type ZBookmarkList = z.infer<typeof zBookmarkListSchema>;
-export type ZBookmarkListWithBookmarks = z.infer<
- typeof zBookmarkListWithBookmarksSchema
->;
+
+export const zEditBookmarkListSchema = z.object({
+ listId: z.string(),
+ name: z
+ .string()
+ .min(1, "List name can't be empty")
+ .max(40, "List name is at most 40 chars")
+ .optional(),
+ icon: z.string().optional(),
+ parentId: z.string().nullish(),
+ query: z.string().min(1).optional(),
+});
+
+export const zEditBookmarkListSchemaWithValidation = zEditBookmarkListSchema
+ .refine((val) => val.parentId != val.listId, {
+ message: "List can't be its own parent",
+ path: ["parentId"],
+ })
+ .refine(
+ (val) => !val.query || parseSearchQuery(val.query).result === "full",
+ {
+ message: "Smart search query is not valid",
+ path: ["query"],
+ },
+ )
+ .refine((val) => !val.query || parseSearchQuery(val.query).text.length == 0, {
+ message:
+ "Smart lists cannot have unqualified terms (aka full text search terms) in the query",
+ path: ["query"],
+ });