@devvistatech/devvista-kit 0.0.10 → 0.0.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (306) hide show
  1. package/CHANGELOG.md +12 -12
  2. package/LICENSE +6 -6
  3. package/README.md +15 -15
  4. package/app/about/page.tsx +298 -298
  5. package/app/adRequest/page.tsx +549 -549
  6. package/app/analytics/page.tsx +346 -346
  7. package/app/api/about/route.ts +306 -306
  8. package/app/api/adRequest/route.ts +567 -567
  9. package/app/api/analytics/[reportType]/route.ts +337 -337
  10. package/app/api/bio/route.ts +313 -313
  11. package/app/api/blog/route.ts +306 -306
  12. package/app/api/chat/route.ts +14 -14
  13. package/app/api/contact/route.ts +409 -409
  14. package/app/api/contacts/route.ts +224 -224
  15. package/app/api/files/route.ts +429 -429
  16. package/app/api/gallery-data/route.ts +735 -735
  17. package/app/api/schedule/route.ts +455 -455
  18. package/app/api/sync-user/route.ts +131 -131
  19. package/app/api/trial-request/route.ts +297 -297
  20. package/app/blog/[id]/page.tsx +288 -288
  21. package/app/blog/page.tsx +216 -216
  22. package/app/contact/page.tsx +284 -284
  23. package/app/faq/page.tsx +191 -191
  24. package/app/gallery/page.tsx +315 -315
  25. package/app/globals.css +58 -58
  26. package/app/layout.tsx +110 -110
  27. package/app/not-found.tsx +20 -20
  28. package/app/page.tsx +338 -338
  29. package/app/schedule/page.tsx +660 -660
  30. package/bin/init.js +219 -219
  31. package/components/addOns/functional/BioEditor.tsx +446 -446
  32. package/components/addOns/functional/CalendlyWidget.tsx +107 -107
  33. package/components/addOns/functional/ClassList.tsx +145 -145
  34. package/components/addOns/functional/ClassPopup.tsx +398 -398
  35. package/components/addOns/functional/ContactForm.tsx +284 -284
  36. package/components/addOns/functional/FileUploader.tsx +294 -294
  37. package/components/addOns/functional/ImageDescCarousel.tsx +730 -730
  38. package/components/addOns/functional/NewUserAnalytics.tsx +100 -100
  39. package/components/addOns/functional/ScheduleCarousel.tsx +171 -171
  40. package/components/addOns/functional/aboutSections/AboutSection.tsx +544 -544
  41. package/components/addOns/functional/aboutSections/constants/aboutSection.ts +65 -65
  42. package/components/addOns/functional/blogSections/BlogDashboard.tsx +184 -184
  43. package/components/addOns/functional/blogSections/BlogFormPopUp.tsx +554 -554
  44. package/components/addOns/functional/blogSections/BlogList.tsx +148 -148
  45. package/components/addOns/functional/blogSections/BlogSidebar.tsx +58 -58
  46. package/components/addOns/functional/blogSections/constants/blogDashboard.ts +28 -28
  47. package/components/addOns/functional/blogSections/constants/blogFormPopUp.ts +97 -97
  48. package/components/addOns/functional/blogSections/constants/blogList.ts +22 -22
  49. package/components/addOns/functional/blogSections/constants/blogSidebar.ts +15 -15
  50. package/components/addOns/functional/contactsDashboard/ContactsDashboard.tsx +366 -366
  51. package/components/addOns/functional/contactsDashboard/constants/contactsDashboard.ts +70 -70
  52. package/components/addOns/functional/galleries/GalleryComplex.tsx +836 -836
  53. package/components/addOns/functional/galleries/GallerySimple.tsx +509 -509
  54. package/components/addOns/functional/galleries/constants/galleryComplex.ts +106 -106
  55. package/components/addOns/functional/galleries/constants/gallerySimple.ts +76 -76
  56. package/components/addOns/functional/schedules/ScheduleGridOne.tsx +262 -262
  57. package/components/addOns/functional/schedules/ScheduleGridTwo.tsx +294 -294
  58. package/components/addOns/functional/schedules/ScheduleGridTwoBasic.tsx +288 -288
  59. package/components/addOns/functional/schedules/SchedulerForm.tsx +428 -428
  60. package/components/addOns/functional/schedules/constants/ScheduleGridTwo.ts +40 -40
  61. package/components/addOns/functional/schedules/constants/ScheduleGridTwoBasic.ts +40 -40
  62. package/components/addOns/functional/schedules/constants/SchedulerForm.ts +65 -65
  63. package/components/addOns/functional/schedules/constants/scheduleGridOne.ts +54 -54
  64. package/components/addOns/non-functional/AnnouncementBanner.tsx +46 -46
  65. package/components/addOns/non-functional/FeaturesSection.tsx +62 -62
  66. package/components/addOns/non-functional/Heros/HeroSection.tsx +142 -142
  67. package/components/addOns/non-functional/IconBubble.tsx +49 -49
  68. package/components/addOns/non-functional/SampleCarousel.tsx +204 -204
  69. package/components/addOns/non-functional/Testimonials.tsx +334 -334
  70. package/components/addOns/non-functional/ThreeSetGallery.tsx +63 -63
  71. package/components/addOns/non-functional/aboutSections/AboutSection.tsx +62 -62
  72. package/components/addOns/non-functional/aboutSections/constants/aboutSection.ts +24 -24
  73. package/components/addOns/non-functional/imageCarousels/ProductSlider.tsx +117 -117
  74. package/components/addOns/non-functional/imageCarousels/ProgramCarousel.tsx +232 -232
  75. package/components/addOns/non-functional/imageCarousels/constants/programCarousel.ts +39 -39
  76. package/components/addOns/non-functional/imageCarousels/constants/programSlider.ts +36 -36
  77. package/components/addOns/non-functional/spinner.tsx +21 -21
  78. package/components/footers/footer.tsx +453 -453
  79. package/components/navBars/navbar.tsx +310 -310
  80. package/components/other/accordion.tsx +58 -58
  81. package/components/other/admin-menu.tsx +68 -68
  82. package/components/other/alert-dialog.tsx +141 -141
  83. package/components/other/alert.tsx +59 -59
  84. package/components/other/aspect-ratio.tsx +7 -7
  85. package/components/other/avatar.tsx +50 -50
  86. package/components/other/badge.tsx +36 -36
  87. package/components/other/breadcrumb.tsx +115 -115
  88. package/components/other/button.tsx +738 -738
  89. package/components/other/calendar.tsx +66 -66
  90. package/components/other/card.tsx +86 -86
  91. package/components/other/carousel.tsx +274 -274
  92. package/components/other/chart.tsx +363 -363
  93. package/components/other/checkbox.tsx +30 -30
  94. package/components/other/collapsible.tsx +11 -11
  95. package/components/other/command.tsx +155 -155
  96. package/components/other/context-menu.tsx +200 -200
  97. package/components/other/dialog.tsx +122 -122
  98. package/components/other/drawer.tsx +118 -118
  99. package/components/other/dropdown-menu.tsx +200 -200
  100. package/components/other/form.tsx +179 -179
  101. package/components/other/hover-card.tsx +29 -29
  102. package/components/other/input-otp.tsx +71 -71
  103. package/components/other/input.tsx +25 -25
  104. package/components/other/label.tsx +26 -26
  105. package/components/other/menubar.tsx +236 -236
  106. package/components/other/mobile-icon.tsx +21 -21
  107. package/components/other/navigation-menu.tsx +128 -128
  108. package/components/other/pagination.tsx +117 -117
  109. package/components/other/popover.tsx +31 -31
  110. package/components/other/progress.tsx +28 -28
  111. package/components/other/radio-group.tsx +44 -44
  112. package/components/other/resizable.tsx +45 -45
  113. package/components/other/scroll-area.tsx +48 -48
  114. package/components/other/select.tsx +160 -160
  115. package/components/other/separator.tsx +31 -31
  116. package/components/other/sheet.tsx +140 -140
  117. package/components/other/skeleton.tsx +15 -15
  118. package/components/other/slider.tsx +28 -28
  119. package/components/other/social-icons.tsx +39 -39
  120. package/components/other/sonner.tsx +31 -31
  121. package/components/other/switch.tsx +29 -29
  122. package/components/other/table.tsx +117 -117
  123. package/components/other/tabs.tsx +55 -55
  124. package/components/other/textarea.tsx +24 -24
  125. package/components/other/toast.tsx +122 -122
  126. package/components/other/toaster.tsx +35 -35
  127. package/components/other/toggle-group.tsx +61 -61
  128. package/components/other/toggle.tsx +45 -45
  129. package/components/other/tooltip.tsx +30 -30
  130. package/components/theme-provider.tsx +8 -8
  131. package/components/types.ts +49 -49
  132. package/hooks/use-toast.ts +188 -188
  133. package/lib/auth-context.tsx +130 -130
  134. package/lib/constants/about.ts +34 -34
  135. package/lib/constants/adRequest.ts +113 -113
  136. package/lib/constants/contact.ts +40 -40
  137. package/lib/constants/faq.ts +34 -34
  138. package/lib/constants/gallery.ts +42 -42
  139. package/lib/constants/page.ts +69 -69
  140. package/lib/constants/schedule.ts +71 -71
  141. package/lib/google-analytics.tsx +97 -97
  142. package/lib/verify-user.ts +117 -117
  143. package/middleware.ts +42 -42
  144. package/netlify.toml +5 -5
  145. package/next.config.js +10 -10
  146. package/package.json +115 -115
  147. package/tailwind.config.ts +89 -89
  148. package/tsconfig.json +23 -23
  149. package/dist/.next/types/app/api/about/route.js +0 -52
  150. package/dist/.next/types/app/api/blog/route.js +0 -52
  151. package/dist/.next/types/app/api/files/route.js +0 -52
  152. package/dist/.next/types/app/api/schedule/route.js +0 -52
  153. package/dist/.next/types/app/api/sync-user/route.js +0 -52
  154. package/dist/.next/types/app/layout.js +0 -22
  155. package/dist/.next/types/app/page.js +0 -22
  156. package/dist/app/about/page.jsx +0 -258
  157. package/dist/app/adRequest/page.jsx +0 -531
  158. package/dist/app/analytics/page.jsx +0 -298
  159. package/dist/app/api/about/route.js +0 -285
  160. package/dist/app/api/adRequest/route.js +0 -440
  161. package/dist/app/api/analytics/[reportType]/route.js +0 -357
  162. package/dist/app/api/bio/route.js +0 -293
  163. package/dist/app/api/blog/route.js +0 -366
  164. package/dist/app/api/chat/route.js +0 -58
  165. package/dist/app/api/contact/route.js +0 -163
  166. package/dist/app/api/contacts/route.js +0 -234
  167. package/dist/app/api/files/route.js +0 -444
  168. package/dist/app/api/gallery-data/route.js +0 -719
  169. package/dist/app/api/schedule/route.js +0 -461
  170. package/dist/app/api/sync-user/route.js +0 -186
  171. package/dist/app/api/trial-request/route.js +0 -165
  172. package/dist/app/blog/[id]/page.jsx +0 -312
  173. package/dist/app/blog/page.jsx +0 -210
  174. package/dist/app/constants/about.js +0 -32
  175. package/dist/app/constants/adRequest.js +0 -113
  176. package/dist/app/constants/contact.js +0 -40
  177. package/dist/app/constants/faq.js +0 -36
  178. package/dist/app/constants/gallery.js +0 -42
  179. package/dist/app/constants/page.js +0 -69
  180. package/dist/app/constants/schedule.js +0 -71
  181. package/dist/app/contact/page.jsx +0 -119
  182. package/dist/app/faq/page.jsx +0 -97
  183. package/dist/app/gallery/page.jsx +0 -281
  184. package/dist/app/layout.jsx +0 -45
  185. package/dist/app/not-found.jsx +0 -14
  186. package/dist/app/page.jsx +0 -324
  187. package/dist/app/schedule/page.jsx +0 -500
  188. package/dist/components/addOns/functional/BioEditor.jsx +0 -187
  189. package/dist/components/addOns/functional/CalendlyWidget.jsx +0 -61
  190. package/dist/components/addOns/functional/ClassList.jsx +0 -158
  191. package/dist/components/addOns/functional/ClassPopup.jsx +0 -300
  192. package/dist/components/addOns/functional/ContactForm.jsx +0 -219
  193. package/dist/components/addOns/functional/FileUploader.jsx +0 -222
  194. package/dist/components/addOns/functional/ImageDescCarousel.jsx +0 -491
  195. package/dist/components/addOns/functional/NewUserAnalytics.jsx +0 -71
  196. package/dist/components/addOns/functional/ScheduleCarousel.jsx +0 -68
  197. package/dist/components/addOns/functional/aboutSections/AboutSection.jsx +0 -372
  198. package/dist/components/addOns/functional/aboutSections/constants/aboutSection.js +0 -65
  199. package/dist/components/addOns/functional/blogSections/BlogDashboard.jsx +0 -111
  200. package/dist/components/addOns/functional/blogSections/BlogFormPopUp.jsx +0 -465
  201. package/dist/components/addOns/functional/blogSections/BlogList.jsx +0 -170
  202. package/dist/components/addOns/functional/blogSections/BlogSidebar.jsx +0 -35
  203. package/dist/components/addOns/functional/blogSections/constants/blogDashboard.js +0 -28
  204. package/dist/components/addOns/functional/blogSections/constants/blogFormPopUp.js +0 -97
  205. package/dist/components/addOns/functional/blogSections/constants/blogList.js +0 -22
  206. package/dist/components/addOns/functional/blogSections/constants/blogSidebar.js +0 -15
  207. package/dist/components/addOns/functional/contactsDashboard/ContactsDashboard.jsx +0 -355
  208. package/dist/components/addOns/functional/contactsDashboard/constants/contactsDashboard.js +0 -70
  209. package/dist/components/addOns/functional/galleries/GalleryComplex.jsx +0 -605
  210. package/dist/components/addOns/functional/galleries/GallerySimple.jsx +0 -363
  211. package/dist/components/addOns/functional/galleries/constants/galleryComplex.js +0 -106
  212. package/dist/components/addOns/functional/galleries/constants/gallerySimple.js +0 -76
  213. package/dist/components/addOns/functional/schedules/ScheduleGridOne.jsx +0 -167
  214. package/dist/components/addOns/functional/schedules/ScheduleGridTwo.jsx +0 -100
  215. package/dist/components/addOns/functional/schedules/ScheduleGridTwoBasic.jsx +0 -97
  216. package/dist/components/addOns/functional/schedules/SchedulerForm.jsx +0 -188
  217. package/dist/components/addOns/functional/schedules/constants/ScheduleGridTwo.js +0 -40
  218. package/dist/components/addOns/functional/schedules/constants/ScheduleGridTwoBasic.js +0 -40
  219. package/dist/components/addOns/functional/schedules/constants/SchedulerForm.js +0 -65
  220. package/dist/components/addOns/functional/schedules/constants/scheduleGridOne.js +0 -54
  221. package/dist/components/addOns/non-functional/AnnouncementBanner.jsx +0 -24
  222. package/dist/components/addOns/non-functional/FeaturesSection.jsx +0 -38
  223. package/dist/components/addOns/non-functional/HeroSection.jsx +0 -71
  224. package/dist/components/addOns/non-functional/Heros/HeroSection.jsx +0 -71
  225. package/dist/components/addOns/non-functional/IconBubble.jsx +0 -36
  226. package/dist/components/addOns/non-functional/SampleCarousel.jsx +0 -114
  227. package/dist/components/addOns/non-functional/Testimonials.jsx +0 -177
  228. package/dist/components/addOns/non-functional/ThreeSetGallery.jsx +0 -40
  229. package/dist/components/addOns/non-functional/aboutSections/AboutSection.jsx +0 -35
  230. package/dist/components/addOns/non-functional/aboutSections/constants/aboutSection.js +0 -24
  231. package/dist/components/addOns/non-functional/imageCarousels/ProductSlider.jsx +0 -80
  232. package/dist/components/addOns/non-functional/imageCarousels/ProgramCarousel.jsx +0 -155
  233. package/dist/components/addOns/non-functional/imageCarousels/constants/programCarousel.js +0 -39
  234. package/dist/components/addOns/non-functional/imageCarousels/constants/programSlider.js +0 -36
  235. package/dist/components/addOns/non-functional/spinner.jsx +0 -13
  236. package/dist/components/footers/footer.jsx +0 -217
  237. package/dist/components/navBars/navbar.jsx +0 -159
  238. package/dist/components/other/accordion.jsx +0 -40
  239. package/dist/components/other/admin-menu.jsx +0 -34
  240. package/dist/components/other/alert-dialog.jsx +0 -64
  241. package/dist/components/other/alert.jsx +0 -41
  242. package/dist/components/other/aspect-ratio.jsx +0 -4
  243. package/dist/components/other/avatar.jsx +0 -31
  244. package/dist/components/other/badge.jsx +0 -32
  245. package/dist/components/other/breadcrumb.jsx +0 -57
  246. package/dist/components/other/button.jsx +0 -322
  247. package/dist/components/other/calendar.jsx +0 -43
  248. package/dist/components/other/card.jsx +0 -44
  249. package/dist/components/other/carousel.jsx +0 -140
  250. package/dist/components/other/chart.jsx +0 -182
  251. package/dist/components/other/checkbox.jsx +0 -26
  252. package/dist/components/other/collapsible.jsx +0 -6
  253. package/dist/components/other/command.jsx +0 -68
  254. package/dist/components/other/context-menu.jsx +0 -88
  255. package/dist/components/other/dialog.jsx +0 -60
  256. package/dist/components/other/drawer.jsx +0 -60
  257. package/dist/components/other/dropdown-menu.jsx +0 -90
  258. package/dist/components/other/form.jsx +0 -89
  259. package/dist/components/other/hover-card.jsx +0 -23
  260. package/dist/components/other/input-otp.jsx +0 -46
  261. package/dist/components/other/input.jsx +0 -19
  262. package/dist/components/other/label.jsx +0 -23
  263. package/dist/components/other/login-popup.jsx +0 -1
  264. package/dist/components/other/menubar.jsx +0 -96
  265. package/dist/components/other/mobile-icon.jsx +0 -11
  266. package/dist/components/other/navigation-menu.jsx +0 -62
  267. package/dist/components/other/pagination.jsx +0 -63
  268. package/dist/components/other/popover.jsx +0 -25
  269. package/dist/components/other/progress.jsx +0 -23
  270. package/dist/components/other/radio-group.jsx +0 -31
  271. package/dist/components/other/resizable.jsx +0 -29
  272. package/dist/components/other/scroll-area.jsx +0 -36
  273. package/dist/components/other/select.jsx +0 -83
  274. package/dist/components/other/separator.jsx +0 -21
  275. package/dist/components/other/sheet.jsx +0 -74
  276. package/dist/components/other/signup-popup.jsx +0 -1
  277. package/dist/components/other/skeleton.jsx +0 -17
  278. package/dist/components/other/slider.jsx +0 -26
  279. package/dist/components/other/social-icons.jsx +0 -15
  280. package/dist/components/other/sonner.jsx +0 -27
  281. package/dist/components/other/switch.jsx +0 -23
  282. package/dist/components/other/table.jsx +0 -56
  283. package/dist/components/other/tabs.jsx +0 -32
  284. package/dist/components/other/textarea.jsx +0 -19
  285. package/dist/components/other/toast.jsx +0 -58
  286. package/dist/components/other/toaster.jsx +0 -31
  287. package/dist/components/other/toggle-group.jsx +0 -41
  288. package/dist/components/other/toggle.jsx +0 -39
  289. package/dist/components/other/tooltip.jsx +0 -24
  290. package/dist/components/theme-provider.jsx +0 -18
  291. package/dist/components/types.js +0 -1
  292. package/dist/hooks/use-toast.js +0 -135
  293. package/dist/lib/auth-context.jsx +0 -144
  294. package/dist/lib/constants/about.js +0 -32
  295. package/dist/lib/constants/adRequest.js +0 -113
  296. package/dist/lib/constants/contact.js +0 -40
  297. package/dist/lib/constants/faq.js +0 -36
  298. package/dist/lib/constants/gallery.js +0 -42
  299. package/dist/lib/constants/page.js +0 -69
  300. package/dist/lib/constants/schedule.js +0 -71
  301. package/dist/lib/google-analytics.jsx +0 -148
  302. package/dist/lib/utils.js +0 -9
  303. package/dist/lib/verify-user.js +0 -142
  304. package/dist/middleware.js +0 -37
  305. package/dist/tailwind.config.js +0 -86
  306. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,35 +0,0 @@
1
- "use client";
2
- import React from "react";
3
- import Link from "next/link";
4
- import { Card, CardContent, CardHeader, CardTitle } from "@/components/other/card";
5
- import { BLOG_SIDEBAR } from "./constants/blogSidebar";
6
- export default function BlogSidebar(_a) {
7
- var posts = _a.posts, currentPostId = _a.currentPostId;
8
- var otherPosts = posts
9
- .filter(function (post) { return post.id !== currentPostId; })
10
- .sort(function (a, b) { return new Date(b.publishedAt).getTime() - new Date(a.publishedAt).getTime(); })
11
- .slice(0, 5);
12
- return (<Card className="w-full max-w-xs min-h-[300px] rounded-2xl border border-gray-700/50 bg-gray-800/50 backdrop-blur-md shadow-lg hover:border-blue-500/50 transition-colors">
13
- <CardHeader className="pb-4">
14
- <CardTitle className="text-lg font-bold text-white">{BLOG_SIDEBAR.UI.CARD_TITLE}</CardTitle>
15
- </CardHeader>
16
- <CardContent className="p-6">
17
- {otherPosts.length > 0 ? (<ul className="space-y-4">
18
- {otherPosts.map(function (post) { return (<li key={post.id}>
19
- <Link href={"/blog/".concat(post.id)} className="text-gray-200 hover:text-blue-400 transition-colors">
20
- <span className="font-medium text-blue-300 block truncate">
21
- {post.title}
22
- </span>
23
- <div className="text-sm text-white">
24
- {new Date(post.publishedAt).toLocaleDateString("en-US", {
25
- year: "numeric",
26
- month: "long",
27
- day: "numeric",
28
- })}
29
- </div>
30
- </Link>
31
- </li>); })}
32
- </ul>) : (<p className="text-gray-400 text-sm font-medium">{BLOG_SIDEBAR.UI.NO_POSTS_MESSAGE}</p>)}
33
- </CardContent>
34
- </Card>);
35
- }
@@ -1,28 +0,0 @@
1
- // components/addOns/functional/blogSections/constants/blogDashboard.ts
2
- // Constants for hardcoded text in BlogDashboard.tsx, organized by purpose
3
- export var BLOG_DASHBOARD = {
4
- // UI Text for BlogDashboard
5
- UI: {
6
- // Card title
7
- CARD_TITLE: "Blog Posts",
8
- // Card description
9
- CARD_DESCRIPTION: "View and manage your recent blog posts",
10
- // Success message for blog post submission
11
- SUCCESS_MESSAGE: "Blog post submitted successfully!",
12
- // Text when no blog posts exist
13
- NO_POSTS_MESSAGE: "No blog posts yet",
14
- // Subtext when no blog posts exist
15
- NO_POSTS_SUBTEXT: "Submit your first blog post to get started",
16
- },
17
- // Button Text for BlogDashboard
18
- BUTTONS: {
19
- // AddButton text
20
- ADD_BUTTON: "Add New Post",
21
- // EditButton aria-label template
22
- EDIT_BUTTON_ARIA: "Edit ${post.title}",
23
- // TrashButton aria-label template
24
- DELETE_BUTTON_ARIA: "Delete ${post.title}",
25
- },
26
- // Error Messages for BlogDashboard
27
- ERRORS: {}, // No direct errors in JSX
28
- };
@@ -1,97 +0,0 @@
1
- // components/addOns/functional/blogSections/constants/blogFormPopUp.ts
2
- // Constants for hardcoded text in BlogFormPopUp.tsx, organized by purpose
3
- export var BLOG_FORM_POP_UP = {
4
- // UI Text for BlogFormPopUp
5
- UI: {
6
- // Modal heading when editing
7
- EDIT_MODAL_HEADING: "Edit Blog Post",
8
- // Modal heading when adding
9
- ADD_MODAL_HEADING: "Add New Blog Post",
10
- // Label for title input
11
- TITLE_LABEL: "Title",
12
- // Placeholder for title input
13
- TITLE_PLACEHOLDER: "Enter post title",
14
- // Title character and word count template
15
- TITLE_COUNT_TEXT: "${titleCharCount}/50 characters, ${titleWordCount} words",
16
- // Label for author input
17
- AUTHOR_LABEL: "Author",
18
- // Label for description textarea
19
- DESCRIPTION_LABEL: "Description",
20
- // Placeholder for description textarea
21
- DESCRIPTION_PLACEHOLDER: "Enter post description",
22
- // Description character and word count template
23
- DESCRIPTION_COUNT_TEXT: "${descriptionCharCount}/1500 characters, ${descriptionWordCount} words",
24
- // ToggleButton text when keywords are shown
25
- HIDE_KEYWORDS_BUTTON: "Hide Keywords",
26
- // ToggleButton text when keywords are hidden
27
- SHOW_KEYWORDS_BUTTON: "Show SEO Keywords",
28
- // SEO keywords for form
29
- SEO_KEYWORDS: [
30
- "fitness training",
31
- "gym workout plans",
32
- "strength exercises",
33
- "cardio routines",
34
- "weight loss tips",
35
- "muscle building",
36
- "home workouts",
37
- "personal trainer",
38
- "fitness motivation",
39
- "healthy lifestyle",
40
- "gym equipment",
41
- "bodybuilding tips",
42
- "HIIT workouts",
43
- "nutrition for fitness",
44
- "exercise routines",
45
- ],
46
- // Aria-label for keyword list items
47
- KEYWORD_ARIA: "Insert keyword: ${keyword}",
48
- // Chatbot heading
49
- CHATBOT_HEADING: "AI Chatbot is coming soon!",
50
- // Chatbot input placeholder
51
- CHATBOT_PLACEHOLDER: "Ask for suggestions...",
52
- // Delete confirmation modal heading
53
- DELETE_MODAL_HEADING: "Confirm Deletion",
54
- // Delete confirmation message
55
- DELETE_CONFIRMATION_TEXT: "Are you sure you want to delete the post &quot;${postToDelete.title}&quot;? This action cannot be undone.",
56
- // System prompt for chatbot
57
- CHATBOT_SYSTEM_PROMPT: "You are an AI assistant helping with blog writing and SEO optimization. You are aware of the current blog post's title: \"${formData.title}\", description: \"${formData.description}\", and the following SEO keywords: ${seoKeywords.join(', ')}. Provide suggestions to improve the blog post's SEO, such as keyword usage, content structure, or meta descriptions. Respond concisely and relevantly to user queries.",
58
- },
59
- // Button Text for BlogFormPopUp
60
- BUTTONS: {
61
- // UpdateButton text when loading
62
- SAVING_BUTTON: "Saving...",
63
- // UpdateButton text when editing
64
- UPDATE_BUTTON: "Update",
65
- // UpdateButton text when adding
66
- SUBMIT_BUTTON: "Submit",
67
- // CancelButton text
68
- CANCEL_BUTTON: "Cancel",
69
- // ChatToggleButton aria-label when open
70
- CLOSE_CHATBOT_ARIA: "Close AI chatbot",
71
- // ChatToggleButton aria-label when closed
72
- OPEN_CHATBOT_ARIA: "Open AI chatbot",
73
- // DeleteButton text when loading
74
- DELETING_BUTTON: "Deleting...",
75
- // DeleteButton text
76
- DELETE_BUTTON: "Delete",
77
- },
78
- // Error Messages for BlogFormPopUp
79
- ERRORS: {
80
- // Error when textarea is not initialized
81
- TEXTAREA_NOT_INITIALIZED: "Text area not initialized",
82
- // Error when authentication is loading
83
- AUTH_LOADING: "Authentication is still loading, please wait...",
84
- // Error when not signed in
85
- NOT_SIGNED_IN: "You must be signed in to create or edit a blog post",
86
- // Warning when business title is missing
87
- NO_BUSINESS_TITLE: "Business title not found; using username or default author name",
88
- // Error for incomplete form
89
- REQUIRED_FIELDS: "Please fill in all required fields",
90
- // Error when delete fails
91
- DELETE_FAILED: "Failed to delete blog post",
92
- // Generic error for delete and submit
93
- UNKNOWN_ERROR: "An unknown error occurred",
94
- // Error when submit fails
95
- SUBMIT_FAILED: "Failed to submit blog post",
96
- },
97
- };
@@ -1,22 +0,0 @@
1
- // components/addOns/functional/blogSections/constants/blogList.ts
2
- // Constants for hardcoded text in BlogList.tsx, organized by purpose
3
- export var BLOG_LIST = {
4
- // UI Text for BlogList
5
- UI: {
6
- // Card title
7
- CARD_TITLE: "Latest Blog Posts",
8
- // Card header description
9
- CARD_DESCRIPTION: "Discover our latest tips and updates",
10
- // Text when no blog posts exist
11
- NO_POSTS_MESSAGE: "No blog posts yet. Check back soon for new updates!",
12
- },
13
- // Button Text for BlogList
14
- BUTTONS: {},
15
- // Error Messages for BlogList
16
- ERRORS: {
17
- // Error when fetch fails
18
- FETCH_FAILED: "Failed to fetch blog posts",
19
- // Generic error for fetch
20
- UNKNOWN_ERROR: "An unknown error occurred",
21
- },
22
- };
@@ -1,15 +0,0 @@
1
- // components/addOns/functional/blogSections/constants/blogSidebar.ts
2
- // Constants for hardcoded text in BlogSidebar.tsx, organized by purpose
3
- export var BLOG_SIDEBAR = {
4
- // UI Text for BlogSidebar
5
- UI: {
6
- // Card title
7
- CARD_TITLE: "Other Blog Posts",
8
- // Text when no other posts exist
9
- NO_POSTS_MESSAGE: "No other posts available.",
10
- },
11
- // Button Text for BlogSidebar
12
- BUTTONS: {},
13
- // Error Messages for BlogSidebar
14
- ERRORS: {}, // No errors in JSX
15
- };
@@ -1,355 +0,0 @@
1
- "use client";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __generator = (this && this.__generator) || function (thisArg, body) {
12
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
13
- return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
- function verb(n) { return function (v) { return step([n, v]); }; }
15
- function step(op) {
16
- if (f) throw new TypeError("Generator is already executing.");
17
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
18
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
19
- if (y = 0, t) op = [op[0] & 2, t.value];
20
- switch (op[0]) {
21
- case 0: case 1: t = op; break;
22
- case 4: _.label++; return { value: op[1], done: false };
23
- case 5: _.label++; y = op[1]; op = [0]; continue;
24
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
- default:
26
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
- if (t[2]) _.ops.pop();
31
- _.trys.pop(); continue;
32
- }
33
- op = body.call(thisArg, _);
34
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
- }
37
- };
38
- import React, { useState, useEffect, useCallback, useRef } from "react";
39
- import { Card } from "@/components/other/card";
40
- import Spinner from "@/components/addOns/non-functional/spinner";
41
- import { motion } from "framer-motion";
42
- import { useAuth as useClerkAuth, useSession } from "@clerk/nextjs";
43
- import { useStrapiAuth } from "@/lib/auth-context";
44
- import { Bar } from "react-chartjs-2";
45
- import { Chart as ChartJS, CategoryScale, LinearScale, BarElement, Title, Tooltip, Legend, } from "chart.js";
46
- import { debounce } from "lodash";
47
- import { CONTACTS_DASHBOARD } from "./constants/contactsDashboard";
48
- ChartJS.register(CategoryScale, LinearScale, BarElement, Title, Tooltip, Legend);
49
- // Utility function to truncate text
50
- var truncateText = function (text, maxLength) {
51
- if (maxLength === void 0) { maxLength = 30; }
52
- if (text.length <= maxLength)
53
- return text;
54
- return text.slice(0, maxLength) + "...";
55
- };
56
- var ContactsDashboard = function () {
57
- var _a = useClerkAuth(), isSignedIn = _a.isSignedIn, userId = _a.userId;
58
- var session = useSession().session;
59
- var _b = useStrapiAuth(), user = _b.user, authLoading = _b.authLoading, authError = _b.error, checkSession = _b.checkSession;
60
- var _c = useState([]), contacts = _c[0], setContacts = _c[1];
61
- var _d = useState(true), isLoading = _d[0], setIsLoading = _d[1];
62
- var _e = useState(null), error = _e[0], setError = _e[1];
63
- var _f = useState(3), visibleRows = _f[0], setVisibleRows = _f[1];
64
- var _g = useState("all"), selectedYear = _g[0], setSelectedYear = _g[1];
65
- var _h = useState([]), availableYears = _h[0], setAvailableYears = _h[1];
66
- var _j = useState(0), retryCount = _j[0], setRetryCount = _j[1];
67
- var maxRetries = 3;
68
- var hasFetchedRef = useRef(false); // Track if fetch has been completed
69
- var contactsPerRow = 3;
70
- var totalRows = Math.ceil(contacts.length / contactsPerRow);
71
- // Memoize debouncedCheckSession to ensure it doesn't change
72
- var debouncedCheckSession = useCallback(debounce(function () { return __awaiter(void 0, void 0, void 0, function () {
73
- return __generator(this, function (_a) {
74
- switch (_a.label) {
75
- case 0: return [4 /*yield*/, checkSession()];
76
- case 1:
77
- _a.sent();
78
- return [2 /*return*/];
79
- }
80
- });
81
- }); }, 3000), [checkSession]);
82
- var fetchContacts = useCallback(function () { return __awaiter(void 0, void 0, void 0, function () {
83
- var token, response, errorData, result, fetchedContacts, validContacts, sortedContacts, years, err_1;
84
- return __generator(this, function (_a) {
85
- switch (_a.label) {
86
- case 0:
87
- _a.trys.push([0, 6, 7, 8]);
88
- setIsLoading(true);
89
- return [4 /*yield*/, (session === null || session === void 0 ? void 0 : session.getToken())];
90
- case 1:
91
- token = _a.sent();
92
- if (!token) {
93
- throw new Error(CONTACTS_DASHBOARD.ERRORS.NO_TOKEN);
94
- }
95
- return [4 /*yield*/, fetch("/api/contacts", {
96
- headers: {
97
- "Content-Type": "application/json",
98
- Authorization: "Bearer ".concat(token),
99
- },
100
- })];
101
- case 2:
102
- response = _a.sent();
103
- if (!!response.ok) return [3 /*break*/, 4];
104
- return [4 /*yield*/, response.json()];
105
- case 3:
106
- errorData = _a.sent();
107
- throw new Error(errorData.error ||
108
- CONTACTS_DASHBOARD.ERRORS.FETCH_FAILED.replace("${response.status}", response.status.toString()));
109
- case 4: return [4 /*yield*/, response.json()];
110
- case 5:
111
- result = _a.sent();
112
- fetchedContacts = (result.data || []).map(function (contact) { return ({
113
- id: contact.id || 0,
114
- documentId: contact.documentId || "",
115
- name: contact.name || "Unknown",
116
- lastName: contact.lastName || "Unknown",
117
- email: contact.email || "N/A",
118
- phone: contact.phone || "N/A",
119
- subject: contact.subject || "No Subject",
120
- message: contact.message || "No Message",
121
- submissionDate: contact.submissionDate
122
- ? new Date(contact.submissionDate).toLocaleString("en-US", {
123
- dateStyle: "medium",
124
- timeStyle: "short",
125
- })
126
- : "N/A",
127
- rawSubmissionDate: contact.submissionDate || "",
128
- }); });
129
- validContacts = fetchedContacts.filter(function (contact) {
130
- return contact.name !== "Unknown" ||
131
- contact.lastName !== "Unknown" ||
132
- contact.email !== "N/A" ||
133
- contact.phone !== "N/A" ||
134
- contact.subject !== "No Subject" ||
135
- contact.message !== "No Message";
136
- });
137
- sortedContacts = validContacts.sort(function (a, b) {
138
- return b.rawSubmissionDate
139
- ? new Date(b.rawSubmissionDate).getTime() - new Date(a.rawSubmissionDate).getTime()
140
- : 0;
141
- });
142
- years = Array.from(new Set(validContacts
143
- .filter(function (contact) { return contact.rawSubmissionDate; })
144
- .map(function (contact) { return new Date(contact.rawSubmissionDate).getFullYear(); }))).sort(function (a, b) { return b - a; });
145
- setAvailableYears(years);
146
- setContacts(sortedContacts);
147
- if (validContacts.length === 0 && fetchedContacts.length > 0) {
148
- setError(CONTACTS_DASHBOARD.ERRORS.NO_VALID_CONTACTS);
149
- }
150
- hasFetchedRef.current = true; // Mark fetch as complete
151
- return [3 /*break*/, 8];
152
- case 6:
153
- err_1 = _a.sent();
154
- setError(err_1 instanceof Error ? err_1.message : CONTACTS_DASHBOARD.ERRORS.UNKNOWN_ERROR);
155
- console.error("ContactsDashboard: Fetch error", err_1);
156
- return [3 /*break*/, 8];
157
- case 7:
158
- setIsLoading(false);
159
- return [7 /*endfinally*/];
160
- case 8: return [2 /*return*/];
161
- }
162
- });
163
- }); }, [session]);
164
- useEffect(function () {
165
- var attemptFetch = function () { return __awaiter(void 0, void 0, void 0, function () {
166
- return __generator(this, function (_a) {
167
- switch (_a.label) {
168
- case 0:
169
- if (authLoading || hasFetchedRef.current) {
170
- setIsLoading(false);
171
- return [2 /*return*/];
172
- }
173
- if (!isSignedIn || !user) {
174
- setError(authError || CONTACTS_DASHBOARD.ERRORS.UNAUTHORIZED);
175
- setIsLoading(false);
176
- if (retryCount < maxRetries) {
177
- setTimeout(function () { return __awaiter(void 0, void 0, void 0, function () {
178
- return __generator(this, function (_a) {
179
- switch (_a.label) {
180
- case 0:
181
- setRetryCount(function (prev) { return Math.min(prev + 1, maxRetries); });
182
- return [4 /*yield*/, debouncedCheckSession()];
183
- case 1:
184
- _a.sent();
185
- if (!!hasFetchedRef.current) return [3 /*break*/, 3];
186
- return [4 /*yield*/, fetchContacts()];
187
- case 2:
188
- _a.sent();
189
- _a.label = 3;
190
- case 3: return [2 /*return*/];
191
- }
192
- });
193
- }); }, Math.min(Math.pow(2, retryCount) * 1000, 10000));
194
- }
195
- return [2 /*return*/];
196
- }
197
- setRetryCount(0);
198
- return [4 /*yield*/, fetchContacts()];
199
- case 1:
200
- _a.sent();
201
- return [2 /*return*/];
202
- }
203
- });
204
- }); };
205
- attemptFetch();
206
- }, [isSignedIn, user, authLoading, authError, debouncedCheckSession, fetchContacts]);
207
- var handleRetry = useCallback(function () { return __awaiter(void 0, void 0, void 0, function () {
208
- return __generator(this, function (_a) {
209
- switch (_a.label) {
210
- case 0:
211
- setIsLoading(true);
212
- setError(null);
213
- setRetryCount(0);
214
- hasFetchedRef.current = false; // Reset fetch guard
215
- return [4 /*yield*/, debouncedCheckSession()];
216
- case 1:
217
- _a.sent();
218
- return [4 /*yield*/, fetchContacts()];
219
- case 2:
220
- _a.sent();
221
- return [2 /*return*/];
222
- }
223
- });
224
- }); }, [debouncedCheckSession, fetchContacts]);
225
- var getChartData = function () {
226
- var uniqueEmails = new Set();
227
- var uniqueContacts = contacts.filter(function (contact) {
228
- if (contact.email === "N/A" || uniqueEmails.has(contact.email)) {
229
- return false;
230
- }
231
- uniqueEmails.add(contact.email);
232
- return true;
233
- });
234
- var filteredContacts = selectedYear === "all"
235
- ? uniqueContacts
236
- : uniqueContacts.filter(function (contact) {
237
- return contact.rawSubmissionDate &&
238
- new Date(contact.rawSubmissionDate).getFullYear() === selectedYear;
239
- });
240
- var leadsByMonth = Array(12).fill(0);
241
- filteredContacts.forEach(function (contact) {
242
- if (contact.rawSubmissionDate) {
243
- var month = new Date(contact.rawSubmissionDate).getMonth();
244
- leadsByMonth[month]++;
245
- }
246
- });
247
- return {
248
- labels: CONTACTS_DASHBOARD.UI.MONTH_LABELS,
249
- datasets: [
250
- {
251
- label: "New Leads",
252
- data: leadsByMonth,
253
- backgroundColor: "rgba(59, 130, 246, 0.5)",
254
- borderColor: "rgba(59, 130, 246, 1)",
255
- borderWidth: 1,
256
- },
257
- ],
258
- };
259
- };
260
- var chartOptions = {
261
- responsive: true,
262
- plugins: {
263
- legend: { position: "top" },
264
- title: { display: true, text: CONTACTS_DASHBOARD.UI.CHART_TITLE },
265
- },
266
- scales: {
267
- y: { beginAtZero: true, title: { display: true, text: CONTACTS_DASHBOARD.UI.Y_AXIS_TITLE } },
268
- x: { title: { display: true, text: CONTACTS_DASHBOARD.UI.X_AXIS_TITLE } },
269
- },
270
- };
271
- var handleShowMore = function () {
272
- setVisibleRows(function (prev) { return prev + 3; });
273
- };
274
- var handleCloseAll = function () {
275
- setVisibleRows(3);
276
- };
277
- if (authLoading || isLoading) {
278
- return <Spinner />;
279
- }
280
- if (error || authError) {
281
- return (<div className="bg-red-900/50 border-l-4 border-red-600 p-4 rounded-lg backdrop-blur-sm text-center">
282
- <p className="text-red-300">{error || authError}</p>
283
- <button onClick={handleRetry} className="mt-2 bg-blue-600 text-white px-3 py-1 rounded-lg hover:bg-blue-500">
284
- {CONTACTS_DASHBOARD.BUTTONS.RETRY_BUTTON}
285
- </button>
286
- </div>);
287
- }
288
- return (<section className="bg-gradient-to-br from-blue-600/80 to-gray-800/80 backdrop-blur-md rounded-2xl shadow-lg p-6 border border-blue-500/30 hover:border-blue-400/50 transition-all">
289
- <motion.h2 initial={{ opacity: 0, y: -20 }} animate={{ opacity: 1, y: 0 }} className="text-2xl font-bold text-blue-200 mb-6">
290
- {CONTACTS_DASHBOARD.UI.SECTION_HEADING}
291
- </motion.h2>
292
-
293
- <div className="mb-8">
294
- <div className="flex justify-between items-center mb-4">
295
- <h3 className="text-lg font-semibold text-blue-200">{CONTACTS_DASHBOARD.UI.CHART_SUBHEADING}</h3>
296
- <div>
297
- <label htmlFor="yearFilter" className="text-gray-200 mr-2">
298
- {CONTACTS_DASHBOARD.UI.YEAR_FILTER_LABEL}
299
- </label>
300
- <select id="yearFilter" value={selectedYear} onChange={function (e) { return setSelectedYear(e.target.value === "all" ? "all" : Number(e.target.value)); }} className="bg-gray-800 text-gray-200 border border-gray-700 rounded px-2 py-1">
301
- <option value="all">{CONTACTS_DASHBOARD.UI.ALL_YEARS_OPTION}</option>
302
- {availableYears.map(function (year) { return (<option key={year} value={year}>
303
- {year}
304
- </option>); })}
305
- </select>
306
- </div>
307
- </div>
308
- <div className="bg-gray-800/50 p-4 rounded-lg">
309
- <Bar data={getChartData()} options={chartOptions}/>
310
- </div>
311
- </div>
312
-
313
- <div>
314
- {contacts.length === 0 ? (<p className="text-gray-400 text-center py-4">{CONTACTS_DASHBOARD.UI.NO_CONTACTS_MESSAGE}</p>) : (<>
315
- <div className="grid gap-6 md:grid-cols-2 lg:grid-cols-3">
316
- {contacts.slice(0, visibleRows * contactsPerRow).map(function (contact) { return (<Card key={contact.documentId} className="bg-gray-800/50 backdrop-blur-md border border-gray-700/50 rounded-2xl p-6 flex flex-col">
317
- <h3 className="text-xl font-bold text-blue-200 mb-3">
318
- {truncateText("".concat(contact.name, " ").concat(contact.lastName))}
319
- </h3>
320
- <p className="text-gray-200 font-medium mb-2">
321
- <strong>{CONTACTS_DASHBOARD.UI.EMAIL_LABEL}</strong>{" "}
322
- <a href={"mailto:".concat(contact.email)} className="text-blue-300 hover:underline">
323
- {truncateText(contact.email)}
324
- </a>
325
- </p>
326
- <p className="text-gray-200 font-medium mb-2">
327
- <strong>{CONTACTS_DASHBOARD.UI.PHONE_LABEL}</strong>{" "}
328
- <a href={"tel:".concat(contact.phone)} className="text-blue-300 hover:underline">
329
- {truncateText(contact.phone)}
330
- </a>
331
- </p>
332
- <p className="text-gray-200 font-medium mb-2">
333
- <strong>{CONTACTS_DASHBOARD.UI.SUBJECT_LABEL}</strong> {truncateText(contact.subject)}
334
- </p>
335
- <p className="text-gray-200 font-medium mb-2">
336
- <strong>{CONTACTS_DASHBOARD.UI.MESSAGE_LABEL}</strong> {truncateText(contact.message)}
337
- </p>
338
- <p className="text-gray-200 font-medium">
339
- <strong>{CONTACTS_DASHBOARD.UI.SUBMITTED_LABEL}</strong> {truncateText(contact.submissionDate)}
340
- </p>
341
- </Card>); })}
342
- </div>
343
- <div className="flex gap-4 mt-4">
344
- {visibleRows < totalRows && (<button onClick={handleShowMore} className="bg-blue-500 text-white px-4 py-2 rounded hover:bg-blue-600 transition">
345
- {CONTACTS_DASHBOARD.BUTTONS.SHOW_MORE_BUTTON}
346
- </button>)}
347
- {visibleRows > 3 && (<button onClick={handleCloseAll} className="bg-gray-500 text-white px-4 py-2 rounded hover:bg-gray-600 transition">
348
- {CONTACTS_DASHBOARD.BUTTONS.CLOSE_ALL_BUTTON}
349
- </button>)}
350
- </div>
351
- </>)}
352
- </div>
353
- </section>);
354
- };
355
- export default ContactsDashboard;
@@ -1,70 +0,0 @@
1
- // components/addOns/functional/contactsDashboard/constants/ContactsDashboard.ts
2
- // Constants for hardcoded text in ContactsDashboard.tsx, organized by purpose
3
- export var CONTACTS_DASHBOARD = {
4
- // UI Text for ContactsDashboard
5
- UI: {
6
- // Section heading
7
- SECTION_HEADING: "Contact Submissions",
8
- // Subheading for chart section
9
- CHART_SUBHEADING: "Leads Overview",
10
- // Label for year filter select
11
- YEAR_FILTER_LABEL: "Filter by Year:",
12
- // Option in year filter select
13
- ALL_YEARS_OPTION: "All Years",
14
- // Chart title
15
- CHART_TITLE: "New Leads by Month (Unique Emails)",
16
- // Chart y-axis title
17
- Y_AXIS_TITLE: "Number of Leads",
18
- // Chart x-axis title
19
- X_AXIS_TITLE: "Month",
20
- // Chart month labels
21
- MONTH_LABELS: [
22
- "Jan",
23
- "Feb",
24
- "Mar",
25
- "Apr",
26
- "May",
27
- "Jun",
28
- "Jul",
29
- "Aug",
30
- "Sep",
31
- "Oct",
32
- "Nov",
33
- "Dec",
34
- ],
35
- // Text when no contacts exist
36
- NO_CONTACTS_MESSAGE: "No valid contact submissions found.",
37
- // Label for email field
38
- EMAIL_LABEL: "Email:",
39
- // Label for phone field
40
- PHONE_LABEL: "Phone:",
41
- // Label for subject field
42
- SUBJECT_LABEL: "Subject:",
43
- // Label for message field
44
- MESSAGE_LABEL: "Message:",
45
- // Label for submission date field
46
- SUBMITTED_LABEL: "Submitted:",
47
- },
48
- // Button Text for ContactsDashboard
49
- BUTTONS: {
50
- // Retry button text
51
- RETRY_BUTTON: "Retry",
52
- // Show More button text
53
- SHOW_MORE_BUTTON: "Show More",
54
- // Close All button text
55
- CLOSE_ALL_BUTTON: "Close All",
56
- },
57
- // Error Messages for ContactsDashboard
58
- ERRORS: {
59
- // Error when token is missing
60
- NO_TOKEN: "No JWT token found from Clerk",
61
- // Error when fetch fails with status code
62
- FETCH_FAILED: "Failed to fetch contacts: ${response.status}",
63
- // Generic error for fetch
64
- UNKNOWN_ERROR: "An unknown error occurred",
65
- // Error when not signed in
66
- UNAUTHORIZED: "Unauthorized: Please log in to view the contacts dashboard",
67
- // Error when all contacts are invalid
68
- NO_VALID_CONTACTS: "No valid contact submissions found. All entries have incomplete data.",
69
- },
70
- };