qia/ui/pencil-new.pen
ddshi 2dbb1069a6 feat: 初始化项目结构和认证系统
- 添加React + Vite前端项目 (client)
- 添加Node.js + Express后端项目 (server)
- 实现JWT认证系统 (注册/登录/刷新Token)
- 添加Prisma ORM配置 (SQLite/PostgreSQL)
- 配置Tailwind CSS和Mantine组件库

Co-Authored-By: Claude (MiniMax-M2.1) <noreply@anthropic.com>
2026-01-29 15:08:50 +08:00

1090 lines
33 KiB
Plaintext

{
"version": "2.6",
"children": [
{
"type": "frame",
"id": "AyUvt",
"x": -500,
"y": -1401,
"name": "宣传页",
"width": 1200,
"height": 900,
"fill": "#FAFAFA",
"layout": "vertical",
"children": [
{
"type": "frame",
"id": "UqST5",
"name": "navBar",
"width": 1200,
"height": 64,
"fill": "rgba(255,255,255,0)",
"padding": 32,
"justifyContent": "space_between",
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "nDzKF",
"name": "navLeft",
"gap": 12,
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "6A4Yg",
"name": "logoIcon",
"width": 36,
"height": 36,
"fill": "#007AFF",
"cornerRadius": 10
},
{
"type": "text",
"id": "Uu477",
"name": "navTitle",
"fill": "#1C1C1E",
"content": "掐日子",
"fontFamily": "Inter",
"fontSize": 20,
"fontWeight": "700"
}
]
},
{
"type": "text",
"id": "VTP7D",
"name": "navSlogan",
"fill": "#8E8E93",
"content": "AI 纪念日·提醒",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "normal"
},
{
"type": "frame",
"id": "13DG8",
"name": "loginBtn",
"width": 88,
"height": 40,
"fill": "#007AFF",
"cornerRadius": 20,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "4O7in",
"name": "loginText",
"fill": "#FFFFFF",
"content": "登录",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "600"
}
]
}
]
},
{
"type": "frame",
"id": "oAEFk",
"name": "heroSection",
"width": 1200,
"height": 400,
"layout": "vertical",
"gap": 16,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "EgKmg",
"name": "heroTitle",
"fill": "#1C1C1E",
"content": "记住每一个重要的日子",
"textAlign": "center",
"fontFamily": "Inter",
"fontSize": 44,
"fontWeight": "700"
},
{
"type": "text",
"id": "W7EYP",
"name": "heroDesc",
"fill": "#8E8E93",
"content": "AI 智能识别 · 农历公历双支持 · 准时提醒",
"textAlign": "center",
"fontFamily": "Inter",
"fontSize": 18,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "TvVsD",
"name": "ctaSection",
"width": 1200,
"height": 160,
"layout": "vertical",
"gap": 12,
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "Xx5Xt",
"name": "primaryCta",
"width": 200,
"height": 52,
"fill": "#007AFF",
"cornerRadius": 26,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "O0aEY",
"name": "primaryText",
"fill": "#FFFFFF",
"content": "立即开始使用",
"fontFamily": "Inter",
"fontSize": 17,
"fontWeight": "600"
}
]
},
{
"type": "text",
"id": "Rz695",
"name": "secondaryCta",
"fill": "#007AFF",
"content": "已有账号?立即登录",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "WWToz",
"name": "featuresRow",
"width": 1200,
"height": 120,
"gap": 48,
"padding": 32,
"justifyContent": "center",
"children": [
{
"type": "frame",
"id": "Zbk03",
"name": "feature1",
"width": 280,
"layout": "vertical",
"gap": 8,
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "4YZgB",
"name": "f1Icon",
"width": 48,
"height": 48,
"fill": "#E8F0FE",
"cornerRadius": 24
},
{
"type": "text",
"id": "zU4E2",
"name": "f1Title",
"fill": "#1C1C1E",
"content": "AI 智能添加",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "600"
},
{
"type": "text",
"id": "kGs6m",
"name": "f1Desc",
"fill": "#8E8E93",
"content": "自然语言描述,自动识别日期",
"fontFamily": "Inter",
"fontSize": 13,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "5DBj8",
"name": "feature2",
"width": 280,
"fill": "#FFF2E5",
"layout": "vertical",
"gap": 8,
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "GRSMq",
"name": "f1Icon",
"width": 48,
"height": 48,
"fill": "#E8F0FE",
"cornerRadius": 24
},
{
"type": "text",
"id": "BavYR",
"name": "f1Title",
"fill": "#1C1C1E",
"content": "AI 智能添加",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "600"
},
{
"type": "text",
"id": "PUT8S",
"name": "f1Desc",
"fill": "#8E8E93",
"content": "自然语言描述,自动识别日期",
"fontFamily": "Inter",
"fontSize": 13,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "Xm7Qh",
"name": "feature3",
"width": 280,
"fill": "#E5F5ED",
"layout": "vertical",
"gap": 8,
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "kLIXi",
"name": "f1Icon",
"width": 48,
"height": 48,
"fill": "#E8F0FE",
"cornerRadius": 24
},
{
"type": "text",
"id": "KtLXR",
"name": "f1Title",
"fill": "#1C1C1E",
"content": "AI 智能添加",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "600"
},
{
"type": "text",
"id": "K5O65",
"name": "f1Desc",
"fill": "#8E8E93",
"content": "自然语言描述,自动识别日期",
"fontFamily": "Inter",
"fontSize": 13,
"fontWeight": "normal"
}
]
}
]
},
{
"type": "text",
"id": "pCkuV",
"name": "footerText",
"fill": "#C7C7CC",
"content": "© 2025 掐日子 - AI 纪念日·提醒",
"textAlign": "center",
"fontFamily": "Inter",
"fontSize": 12,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "PwXjP",
"x": 1062,
"y": -810,
"name": "登录注册页",
"width": 404,
"height": 530,
"fill": "#FAFAFA",
"layout": "vertical",
"children": [
{
"type": "frame",
"id": "YUspZ",
"name": "authCard",
"width": 400,
"height": 520,
"fill": "#FFFFFF",
"cornerRadius": 24,
"layout": "vertical",
"gap": 24,
"padding": 40,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "VnBxL",
"name": "authLogoArea",
"layout": "vertical",
"gap": 12,
"alignItems": "center",
"children": [
{
"type": "frame",
"id": "QGC7A",
"name": "authLogoIcon",
"width": 56,
"height": 56,
"fill": "#007AFF",
"cornerRadius": 14
},
{
"type": "text",
"id": "CfPbT",
"name": "authLogoText",
"fill": "#1C1C1E",
"content": "掐日子",
"fontFamily": "Inter",
"fontSize": 22,
"fontWeight": "700"
}
]
},
{
"type": "text",
"id": "flmKI",
"name": "authTitle",
"fill": "#1C1C1E",
"content": "欢迎回来",
"fontFamily": "Inter",
"fontSize": 24,
"fontWeight": "600"
},
{
"type": "frame",
"id": "dbIej",
"name": "emailInput",
"width": "fill_container",
"layout": "vertical",
"gap": 8,
"children": [
{
"type": "text",
"id": "sUzgH",
"name": "emailLabel",
"fill": "#1C1C1E",
"content": "邮箱",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "500"
},
{
"type": "frame",
"id": "LvTOv",
"name": "emailField",
"width": "fill_container",
"height": 48,
"fill": "#F2F2F7",
"cornerRadius": 12,
"padding": 16,
"alignItems": "center",
"children": [
{
"type": "text",
"id": "h41CN",
"name": "emailPlaceholder",
"fill": "#8E8E93",
"content": "请输入邮箱地址",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "normal"
}
]
}
]
},
{
"type": "frame",
"id": "7Gtze",
"name": "passwordInput",
"width": "fill_container",
"layout": "vertical",
"gap": 8,
"children": [
{
"type": "text",
"id": "W9TOd",
"name": "passwordLabel",
"fill": "#1C1C1E",
"content": "密码",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "500"
},
{
"type": "frame",
"id": "TmvRf",
"name": "passwordField",
"width": "fill_container",
"height": 48,
"fill": "#F2F2F7",
"cornerRadius": 12,
"padding": 16,
"alignItems": "center",
"children": [
{
"type": "text",
"id": "cXzzD",
"name": "passwordPlaceholder",
"fill": "#8E8E93",
"content": "请输入密码",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "normal"
}
]
}
]
},
{
"type": "frame",
"id": "n5h1L",
"name": "loginButton",
"width": "fill_container",
"height": 48,
"fill": "#007AFF",
"cornerRadius": 24,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "bWCzZ",
"name": "loginBtnText",
"fill": "#FFFFFF",
"content": "登录",
"fontFamily": "Inter",
"fontSize": 16,
"fontWeight": "600"
}
]
},
{
"type": "text",
"id": "bCV1Q",
"name": "toggleLink",
"fill": "#007AFF",
"content": "还没有账号?立即注册",
"textAlign": "center",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "normal"
}
]
}
]
},
{
"type": "frame",
"id": "I2z5N",
"x": 1102,
"y": 522,
"name": "AI确认弹窗",
"width": 420,
"height": 380,
"fill": "#FAFAFA",
"layout": "vertical",
"children": [
{
"type": "frame",
"id": "hi4cJ",
"name": "aiModalCard",
"width": 380,
"height": 340,
"fill": "#FFFFFF",
"cornerRadius": 24,
"layout": "vertical",
"gap": 20,
"padding": 24,
"children": [
{
"type": "text",
"id": "4a0We",
"name": "aiModalTitle",
"fill": "#1C1C1E",
"content": "我帮你记成这样",
"fontFamily": "Inter",
"fontSize": 16,
"fontWeight": "600"
},
{
"type": "frame",
"id": "Kznch",
"name": "aiResultCard",
"width": "fill_container",
"height": 140,
"fill": "#F2F2F7",
"cornerRadius": 16,
"layout": "vertical",
"gap": 12,
"padding": 16,
"children": [
{
"type": "text",
"id": "jHReu",
"name": "aiEventName",
"fill": "#1C1C1E",
"content": "**见客户**",
"fontFamily": "Inter",
"fontSize": 16,
"fontWeight": "600"
},
{
"type": "text",
"id": "wgzx6",
"name": "aiEventDate",
"fill": "#1C1C1E",
"content": "📅 下周三 3月15日",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "normal"
},
{
"type": "text",
"id": "Cxp7j",
"name": "aiEventTime",
"fill": "#1C1C1E",
"content": "⏰ 当天提醒",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "p8rfb",
"name": "aiModalActions",
"width": "fill_container",
"gap": 12,
"children": [
{
"type": "frame",
"id": "pOxSH",
"name": "cancelBtn",
"width": 100,
"height": 44,
"fill": "#F2F2F7",
"cornerRadius": 22,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "hCMxR",
"name": "cancelText",
"fill": "#1C1C1E",
"content": "✏️ 改一下",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "AKOmM",
"name": "confirmBtn",
"width": "fill_container",
"height": 44,
"fill": "#007AFF",
"cornerRadius": 22,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "q7hoO",
"name": "confirmText",
"fill": "#FFFFFF",
"content": "✔ 就这样",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "600"
}
]
}
]
}
]
}
]
},
{
"type": "frame",
"id": "5iG42",
"x": 1387,
"y": -108,
"name": "详情编辑弹窗",
"width": 420,
"height": 480,
"fill": "#FAFAFA",
"layout": "vertical",
"children": [
{
"type": "frame",
"id": "wFqC0",
"name": "detailModalCard",
"width": 380,
"height": 440,
"fill": "#FFFFFF",
"cornerRadius": 24,
"layout": "vertical",
"gap": 20,
"padding": 24,
"children": [
{
"type": "frame",
"id": "UNnRf",
"name": "detailHeader",
"justifyContent": "space_between",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "eCB02",
"name": "detailTitle",
"fill": "#1C1C1E",
"content": "编辑纪念日",
"fontFamily": "Inter",
"fontSize": 18,
"fontWeight": "600"
},
{
"type": "frame",
"id": "x11vg",
"name": "closeBtn",
"width": 32,
"height": 32,
"fill": "#F2F2F7",
"cornerRadius": 16
}
]
},
{
"type": "frame",
"id": "nHUjj",
"name": "detailContent",
"width": "fill_container",
"layout": "vertical",
"gap": 16,
"children": [
{
"type": "frame",
"id": "jkGpA",
"name": "formName",
"width": "fill_container",
"layout": "vertical",
"gap": 8,
"children": [
{
"type": "text",
"id": "E6F5U",
"name": "nameLabel",
"fill": "#1C1C1E",
"content": "名称",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "500"
},
{
"type": "frame",
"id": "aD8Sx",
"name": "nameField",
"width": "fill_container",
"height": 44,
"fill": "#F2F2F7",
"cornerRadius": 10,
"padding": 12,
"alignItems": "center",
"children": [
{
"type": "text",
"id": "orw4z",
"name": "nameValue",
"fill": "#1C1C1E",
"content": "妈妈生日",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "normal"
}
]
}
]
},
{
"type": "frame",
"id": "hgxoK",
"name": "formDate",
"width": "fill_container",
"layout": "vertical",
"gap": 8,
"children": [
{
"type": "text",
"id": "9n5KC",
"name": "dateLabel",
"fill": "#1C1C1E",
"content": "日期",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "500"
},
{
"type": "frame",
"id": "i9Xlg",
"name": "dateRow",
"width": "fill_container",
"gap": 12,
"children": [
{
"type": "frame",
"id": "fUtpm",
"name": "dateField",
"width": "fill_container",
"height": 44,
"fill": "#F2F2F7",
"cornerRadius": 10,
"padding": 12,
"alignItems": "center"
},
{
"type": "frame",
"id": "lsSaY",
"name": "lunarToggle",
"width": 56,
"height": 44,
"fill": "#E8F0FE",
"cornerRadius": 10,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "laNwR",
"name": "lunarText",
"fill": "#007AFF",
"content": "农历",
"fontFamily": "Inter",
"fontSize": 13,
"fontWeight": "500"
}
]
}
]
}
]
},
{
"type": "frame",
"id": "yUU8z",
"name": "formRepeat",
"width": "fill_container",
"layout": "vertical",
"gap": 8,
"children": [
{
"type": "text",
"id": "gjTKW",
"name": "repeatLabel",
"fill": "#1C1C1E",
"content": "重复",
"fontFamily": "Inter",
"fontSize": 14,
"fontWeight": "500"
},
{
"type": "frame",
"id": "jzetu",
"name": "repeatBtns",
"width": "fill_container",
"gap": 8,
"children": [
{
"type": "frame",
"id": "Etgby",
"name": "repeatActive",
"width": 72,
"height": 32,
"fill": "#007AFF",
"cornerRadius": 16,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "8S8Hp",
"name": "repeatText1",
"fill": "#FFFFFF",
"content": "每年",
"fontFamily": "Inter",
"fontSize": 13,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "9SBH5",
"name": "repeatInactive1",
"width": 72,
"height": 32,
"fill": "#FFFFFF",
"cornerRadius": 16,
"stroke": {
"thickness": 1
},
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "potY9",
"name": "repeatText2",
"fill": "#8E8E93",
"content": "每月",
"fontFamily": "Inter",
"fontSize": 13,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "RD2xO",
"name": "repeatInactive2",
"width": 72,
"height": 32,
"fill": "#FFFFFF",
"cornerRadius": 16,
"stroke": {
"thickness": 1
},
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "uvyCt",
"name": "repeatText3",
"fill": "#8E8E93",
"content": "不重复",
"fontFamily": "Inter",
"fontSize": 13,
"fontWeight": "normal"
}
]
}
]
}
]
},
{
"type": "frame",
"id": "Ngq48",
"name": "detailActions",
"width": "fill_container",
"gap": 12,
"children": [
{
"type": "frame",
"id": "rv560",
"name": "deleteBtn",
"width": 72,
"height": 44,
"fill": "#FFEBEA",
"cornerRadius": 22,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "9w65a",
"name": "deleteText",
"fill": "#FF3B30",
"content": "删除",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "normal"
}
]
},
{
"type": "frame",
"id": "Cizf2",
"name": "saveBtn",
"width": "fill_container",
"height": 44,
"fill": "#007AFF",
"cornerRadius": 22,
"justifyContent": "center",
"alignItems": "center",
"children": [
{
"type": "text",
"id": "ybGpQ",
"name": "saveText",
"fill": "#FFFFFF",
"content": "保存",
"fontFamily": "Inter",
"fontSize": 15,
"fontWeight": "600"
}
]
}
]
}
]
}
]
}
]
},
{
"type": "frame",
"id": "slzHj",
"x": 0,
"y": 2000,
"name": "Home页",
"width": 1400,
"height": 1000,
"children": [
{
"type": "rectangle",
"id": "5spL4",
"name": "bgRect",
"fill": "#F5F5F7",
"width": 1400,
"height": 1000
},
{
"type": "rectangle",
"id": "F4Xw2",
"name": "navBar",
"fill": "#FFFFFF",
"width": 1400,
"height": 60
},
{
"type": "frame",
"id": "75IQH",
"name": "annivCol",
"width": 420,
"height": 920,
"gap": 12,
"children": [
{
"type": "text",
"id": "y6wwC",
"name": "annivHeader",
"content": "纪念日",
"fontFamily": "Inter",
"fontSize": 16,
"fontWeight": "600"
},
{
"type": "rectangle",
"cornerRadius": 12,
"id": "svpSJ",
"name": "annivCard",
"fill": "#FFFFFF",
"width": 420,
"height": 72
}
]
},
{
"type": "frame",
"id": "4aGmz",
"name": "remCol",
"width": 420,
"height": 920,
"gap": 12,
"children": [
{
"type": "text",
"id": "XDAcL",
"name": "remHeader",
"content": "提醒",
"fontFamily": "Inter",
"fontSize": 16,
"fontWeight": "600"
},
{
"type": "rectangle",
"cornerRadius": 12,
"id": "E12qc",
"name": "remCard",
"fill": "#FFFFFF",
"width": 420,
"height": 56
}
]
},
{
"type": "frame",
"id": "L1JRA",
"name": "bottomFrame",
"width": 1400,
"height": 320,
"children": [
{
"type": "frame",
"id": "YI6mx",
"name": "aiWrapper",
"width": 460,
"height": 280,
"children": [
{
"type": "rectangle",
"cornerRadius": 16,
"id": "OzqbM",
"name": "aiChat",
"fill": "#FFFFFF",
"width": 460,
"height": 280
}
]
}
]
},
{
"type": "rectangle",
"cornerRadius": 12,
"id": "RJj4p",
"name": "noteArea",
"fill": "#FFFFFF",
"width": 460,
"height": 200
}
]
}
]
}