@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.
- package/CHANGELOG.md +12 -12
- package/LICENSE +6 -6
- package/README.md +15 -15
- package/app/about/page.tsx +298 -298
- package/app/adRequest/page.tsx +549 -549
- package/app/analytics/page.tsx +346 -346
- package/app/api/about/route.ts +306 -306
- package/app/api/adRequest/route.ts +567 -567
- package/app/api/analytics/[reportType]/route.ts +337 -337
- package/app/api/bio/route.ts +313 -313
- package/app/api/blog/route.ts +306 -306
- package/app/api/chat/route.ts +14 -14
- package/app/api/contact/route.ts +409 -409
- package/app/api/contacts/route.ts +224 -224
- package/app/api/files/route.ts +429 -429
- package/app/api/gallery-data/route.ts +735 -735
- package/app/api/schedule/route.ts +455 -455
- package/app/api/sync-user/route.ts +131 -131
- package/app/api/trial-request/route.ts +297 -297
- package/app/blog/[id]/page.tsx +288 -288
- package/app/blog/page.tsx +216 -216
- package/app/contact/page.tsx +284 -284
- package/app/faq/page.tsx +191 -191
- package/app/gallery/page.tsx +315 -315
- package/app/globals.css +58 -58
- package/app/layout.tsx +110 -110
- package/app/not-found.tsx +20 -20
- package/app/page.tsx +338 -338
- package/app/schedule/page.tsx +660 -660
- package/bin/init.js +219 -219
- package/components/addOns/functional/BioEditor.tsx +446 -446
- package/components/addOns/functional/CalendlyWidget.tsx +107 -107
- package/components/addOns/functional/ClassList.tsx +145 -145
- package/components/addOns/functional/ClassPopup.tsx +398 -398
- package/components/addOns/functional/ContactForm.tsx +284 -284
- package/components/addOns/functional/FileUploader.tsx +294 -294
- package/components/addOns/functional/ImageDescCarousel.tsx +730 -730
- package/components/addOns/functional/NewUserAnalytics.tsx +100 -100
- package/components/addOns/functional/ScheduleCarousel.tsx +171 -171
- package/components/addOns/functional/aboutSections/AboutSection.tsx +544 -544
- package/components/addOns/functional/aboutSections/constants/aboutSection.ts +65 -65
- package/components/addOns/functional/blogSections/BlogDashboard.tsx +184 -184
- package/components/addOns/functional/blogSections/BlogFormPopUp.tsx +554 -554
- package/components/addOns/functional/blogSections/BlogList.tsx +148 -148
- package/components/addOns/functional/blogSections/BlogSidebar.tsx +58 -58
- package/components/addOns/functional/blogSections/constants/blogDashboard.ts +28 -28
- package/components/addOns/functional/blogSections/constants/blogFormPopUp.ts +97 -97
- package/components/addOns/functional/blogSections/constants/blogList.ts +22 -22
- package/components/addOns/functional/blogSections/constants/blogSidebar.ts +15 -15
- package/components/addOns/functional/contactsDashboard/ContactsDashboard.tsx +366 -366
- package/components/addOns/functional/contactsDashboard/constants/contactsDashboard.ts +70 -70
- package/components/addOns/functional/galleries/GalleryComplex.tsx +836 -836
- package/components/addOns/functional/galleries/GallerySimple.tsx +509 -509
- package/components/addOns/functional/galleries/constants/galleryComplex.ts +106 -106
- package/components/addOns/functional/galleries/constants/gallerySimple.ts +76 -76
- package/components/addOns/functional/schedules/ScheduleGridOne.tsx +262 -262
- package/components/addOns/functional/schedules/ScheduleGridTwo.tsx +294 -294
- package/components/addOns/functional/schedules/ScheduleGridTwoBasic.tsx +288 -288
- package/components/addOns/functional/schedules/SchedulerForm.tsx +428 -428
- package/components/addOns/functional/schedules/constants/ScheduleGridTwo.ts +40 -40
- package/components/addOns/functional/schedules/constants/ScheduleGridTwoBasic.ts +40 -40
- package/components/addOns/functional/schedules/constants/SchedulerForm.ts +65 -65
- package/components/addOns/functional/schedules/constants/scheduleGridOne.ts +54 -54
- package/components/addOns/non-functional/AnnouncementBanner.tsx +46 -46
- package/components/addOns/non-functional/FeaturesSection.tsx +62 -62
- package/components/addOns/non-functional/Heros/HeroSection.tsx +142 -142
- package/components/addOns/non-functional/IconBubble.tsx +49 -49
- package/components/addOns/non-functional/SampleCarousel.tsx +204 -204
- package/components/addOns/non-functional/Testimonials.tsx +334 -334
- package/components/addOns/non-functional/ThreeSetGallery.tsx +63 -63
- package/components/addOns/non-functional/aboutSections/AboutSection.tsx +62 -62
- package/components/addOns/non-functional/aboutSections/constants/aboutSection.ts +24 -24
- package/components/addOns/non-functional/imageCarousels/ProductSlider.tsx +117 -117
- package/components/addOns/non-functional/imageCarousels/ProgramCarousel.tsx +232 -232
- package/components/addOns/non-functional/imageCarousels/constants/programCarousel.ts +39 -39
- package/components/addOns/non-functional/imageCarousels/constants/programSlider.ts +36 -36
- package/components/addOns/non-functional/spinner.tsx +21 -21
- package/components/footers/footer.tsx +453 -453
- package/components/navBars/navbar.tsx +310 -310
- package/components/other/accordion.tsx +58 -58
- package/components/other/admin-menu.tsx +68 -68
- package/components/other/alert-dialog.tsx +141 -141
- package/components/other/alert.tsx +59 -59
- package/components/other/aspect-ratio.tsx +7 -7
- package/components/other/avatar.tsx +50 -50
- package/components/other/badge.tsx +36 -36
- package/components/other/breadcrumb.tsx +115 -115
- package/components/other/button.tsx +738 -738
- package/components/other/calendar.tsx +66 -66
- package/components/other/card.tsx +86 -86
- package/components/other/carousel.tsx +274 -274
- package/components/other/chart.tsx +363 -363
- package/components/other/checkbox.tsx +30 -30
- package/components/other/collapsible.tsx +11 -11
- package/components/other/command.tsx +155 -155
- package/components/other/context-menu.tsx +200 -200
- package/components/other/dialog.tsx +122 -122
- package/components/other/drawer.tsx +118 -118
- package/components/other/dropdown-menu.tsx +200 -200
- package/components/other/form.tsx +179 -179
- package/components/other/hover-card.tsx +29 -29
- package/components/other/input-otp.tsx +71 -71
- package/components/other/input.tsx +25 -25
- package/components/other/label.tsx +26 -26
- package/components/other/menubar.tsx +236 -236
- package/components/other/mobile-icon.tsx +21 -21
- package/components/other/navigation-menu.tsx +128 -128
- package/components/other/pagination.tsx +117 -117
- package/components/other/popover.tsx +31 -31
- package/components/other/progress.tsx +28 -28
- package/components/other/radio-group.tsx +44 -44
- package/components/other/resizable.tsx +45 -45
- package/components/other/scroll-area.tsx +48 -48
- package/components/other/select.tsx +160 -160
- package/components/other/separator.tsx +31 -31
- package/components/other/sheet.tsx +140 -140
- package/components/other/skeleton.tsx +15 -15
- package/components/other/slider.tsx +28 -28
- package/components/other/social-icons.tsx +39 -39
- package/components/other/sonner.tsx +31 -31
- package/components/other/switch.tsx +29 -29
- package/components/other/table.tsx +117 -117
- package/components/other/tabs.tsx +55 -55
- package/components/other/textarea.tsx +24 -24
- package/components/other/toast.tsx +122 -122
- package/components/other/toaster.tsx +35 -35
- package/components/other/toggle-group.tsx +61 -61
- package/components/other/toggle.tsx +45 -45
- package/components/other/tooltip.tsx +30 -30
- package/components/theme-provider.tsx +8 -8
- package/components/types.ts +49 -49
- package/hooks/use-toast.ts +188 -188
- package/lib/auth-context.tsx +130 -130
- package/lib/constants/about.ts +34 -34
- package/lib/constants/adRequest.ts +113 -113
- package/lib/constants/contact.ts +40 -40
- package/lib/constants/faq.ts +34 -34
- package/lib/constants/gallery.ts +42 -42
- package/lib/constants/page.ts +69 -69
- package/lib/constants/schedule.ts +71 -71
- package/lib/google-analytics.tsx +97 -97
- package/lib/verify-user.ts +117 -117
- package/middleware.ts +42 -42
- package/netlify.toml +5 -5
- package/next.config.js +10 -10
- package/package.json +115 -115
- package/tailwind.config.ts +89 -89
- package/tsconfig.json +23 -23
- package/dist/.next/types/app/api/about/route.js +0 -52
- package/dist/.next/types/app/api/blog/route.js +0 -52
- package/dist/.next/types/app/api/files/route.js +0 -52
- package/dist/.next/types/app/api/schedule/route.js +0 -52
- package/dist/.next/types/app/api/sync-user/route.js +0 -52
- package/dist/.next/types/app/layout.js +0 -22
- package/dist/.next/types/app/page.js +0 -22
- package/dist/app/about/page.jsx +0 -258
- package/dist/app/adRequest/page.jsx +0 -531
- package/dist/app/analytics/page.jsx +0 -298
- package/dist/app/api/about/route.js +0 -285
- package/dist/app/api/adRequest/route.js +0 -440
- package/dist/app/api/analytics/[reportType]/route.js +0 -357
- package/dist/app/api/bio/route.js +0 -293
- package/dist/app/api/blog/route.js +0 -366
- package/dist/app/api/chat/route.js +0 -58
- package/dist/app/api/contact/route.js +0 -163
- package/dist/app/api/contacts/route.js +0 -234
- package/dist/app/api/files/route.js +0 -444
- package/dist/app/api/gallery-data/route.js +0 -719
- package/dist/app/api/schedule/route.js +0 -461
- package/dist/app/api/sync-user/route.js +0 -186
- package/dist/app/api/trial-request/route.js +0 -165
- package/dist/app/blog/[id]/page.jsx +0 -312
- package/dist/app/blog/page.jsx +0 -210
- package/dist/app/constants/about.js +0 -32
- package/dist/app/constants/adRequest.js +0 -113
- package/dist/app/constants/contact.js +0 -40
- package/dist/app/constants/faq.js +0 -36
- package/dist/app/constants/gallery.js +0 -42
- package/dist/app/constants/page.js +0 -69
- package/dist/app/constants/schedule.js +0 -71
- package/dist/app/contact/page.jsx +0 -119
- package/dist/app/faq/page.jsx +0 -97
- package/dist/app/gallery/page.jsx +0 -281
- package/dist/app/layout.jsx +0 -45
- package/dist/app/not-found.jsx +0 -14
- package/dist/app/page.jsx +0 -324
- package/dist/app/schedule/page.jsx +0 -500
- package/dist/components/addOns/functional/BioEditor.jsx +0 -187
- package/dist/components/addOns/functional/CalendlyWidget.jsx +0 -61
- package/dist/components/addOns/functional/ClassList.jsx +0 -158
- package/dist/components/addOns/functional/ClassPopup.jsx +0 -300
- package/dist/components/addOns/functional/ContactForm.jsx +0 -219
- package/dist/components/addOns/functional/FileUploader.jsx +0 -222
- package/dist/components/addOns/functional/ImageDescCarousel.jsx +0 -491
- package/dist/components/addOns/functional/NewUserAnalytics.jsx +0 -71
- package/dist/components/addOns/functional/ScheduleCarousel.jsx +0 -68
- package/dist/components/addOns/functional/aboutSections/AboutSection.jsx +0 -372
- package/dist/components/addOns/functional/aboutSections/constants/aboutSection.js +0 -65
- package/dist/components/addOns/functional/blogSections/BlogDashboard.jsx +0 -111
- package/dist/components/addOns/functional/blogSections/BlogFormPopUp.jsx +0 -465
- package/dist/components/addOns/functional/blogSections/BlogList.jsx +0 -170
- package/dist/components/addOns/functional/blogSections/BlogSidebar.jsx +0 -35
- package/dist/components/addOns/functional/blogSections/constants/blogDashboard.js +0 -28
- package/dist/components/addOns/functional/blogSections/constants/blogFormPopUp.js +0 -97
- package/dist/components/addOns/functional/blogSections/constants/blogList.js +0 -22
- package/dist/components/addOns/functional/blogSections/constants/blogSidebar.js +0 -15
- package/dist/components/addOns/functional/contactsDashboard/ContactsDashboard.jsx +0 -355
- package/dist/components/addOns/functional/contactsDashboard/constants/contactsDashboard.js +0 -70
- package/dist/components/addOns/functional/galleries/GalleryComplex.jsx +0 -605
- package/dist/components/addOns/functional/galleries/GallerySimple.jsx +0 -363
- package/dist/components/addOns/functional/galleries/constants/galleryComplex.js +0 -106
- package/dist/components/addOns/functional/galleries/constants/gallerySimple.js +0 -76
- package/dist/components/addOns/functional/schedules/ScheduleGridOne.jsx +0 -167
- package/dist/components/addOns/functional/schedules/ScheduleGridTwo.jsx +0 -100
- package/dist/components/addOns/functional/schedules/ScheduleGridTwoBasic.jsx +0 -97
- package/dist/components/addOns/functional/schedules/SchedulerForm.jsx +0 -188
- package/dist/components/addOns/functional/schedules/constants/ScheduleGridTwo.js +0 -40
- package/dist/components/addOns/functional/schedules/constants/ScheduleGridTwoBasic.js +0 -40
- package/dist/components/addOns/functional/schedules/constants/SchedulerForm.js +0 -65
- package/dist/components/addOns/functional/schedules/constants/scheduleGridOne.js +0 -54
- package/dist/components/addOns/non-functional/AnnouncementBanner.jsx +0 -24
- package/dist/components/addOns/non-functional/FeaturesSection.jsx +0 -38
- package/dist/components/addOns/non-functional/HeroSection.jsx +0 -71
- package/dist/components/addOns/non-functional/Heros/HeroSection.jsx +0 -71
- package/dist/components/addOns/non-functional/IconBubble.jsx +0 -36
- package/dist/components/addOns/non-functional/SampleCarousel.jsx +0 -114
- package/dist/components/addOns/non-functional/Testimonials.jsx +0 -177
- package/dist/components/addOns/non-functional/ThreeSetGallery.jsx +0 -40
- package/dist/components/addOns/non-functional/aboutSections/AboutSection.jsx +0 -35
- package/dist/components/addOns/non-functional/aboutSections/constants/aboutSection.js +0 -24
- package/dist/components/addOns/non-functional/imageCarousels/ProductSlider.jsx +0 -80
- package/dist/components/addOns/non-functional/imageCarousels/ProgramCarousel.jsx +0 -155
- package/dist/components/addOns/non-functional/imageCarousels/constants/programCarousel.js +0 -39
- package/dist/components/addOns/non-functional/imageCarousels/constants/programSlider.js +0 -36
- package/dist/components/addOns/non-functional/spinner.jsx +0 -13
- package/dist/components/footers/footer.jsx +0 -217
- package/dist/components/navBars/navbar.jsx +0 -159
- package/dist/components/other/accordion.jsx +0 -40
- package/dist/components/other/admin-menu.jsx +0 -34
- package/dist/components/other/alert-dialog.jsx +0 -64
- package/dist/components/other/alert.jsx +0 -41
- package/dist/components/other/aspect-ratio.jsx +0 -4
- package/dist/components/other/avatar.jsx +0 -31
- package/dist/components/other/badge.jsx +0 -32
- package/dist/components/other/breadcrumb.jsx +0 -57
- package/dist/components/other/button.jsx +0 -322
- package/dist/components/other/calendar.jsx +0 -43
- package/dist/components/other/card.jsx +0 -44
- package/dist/components/other/carousel.jsx +0 -140
- package/dist/components/other/chart.jsx +0 -182
- package/dist/components/other/checkbox.jsx +0 -26
- package/dist/components/other/collapsible.jsx +0 -6
- package/dist/components/other/command.jsx +0 -68
- package/dist/components/other/context-menu.jsx +0 -88
- package/dist/components/other/dialog.jsx +0 -60
- package/dist/components/other/drawer.jsx +0 -60
- package/dist/components/other/dropdown-menu.jsx +0 -90
- package/dist/components/other/form.jsx +0 -89
- package/dist/components/other/hover-card.jsx +0 -23
- package/dist/components/other/input-otp.jsx +0 -46
- package/dist/components/other/input.jsx +0 -19
- package/dist/components/other/label.jsx +0 -23
- package/dist/components/other/login-popup.jsx +0 -1
- package/dist/components/other/menubar.jsx +0 -96
- package/dist/components/other/mobile-icon.jsx +0 -11
- package/dist/components/other/navigation-menu.jsx +0 -62
- package/dist/components/other/pagination.jsx +0 -63
- package/dist/components/other/popover.jsx +0 -25
- package/dist/components/other/progress.jsx +0 -23
- package/dist/components/other/radio-group.jsx +0 -31
- package/dist/components/other/resizable.jsx +0 -29
- package/dist/components/other/scroll-area.jsx +0 -36
- package/dist/components/other/select.jsx +0 -83
- package/dist/components/other/separator.jsx +0 -21
- package/dist/components/other/sheet.jsx +0 -74
- package/dist/components/other/signup-popup.jsx +0 -1
- package/dist/components/other/skeleton.jsx +0 -17
- package/dist/components/other/slider.jsx +0 -26
- package/dist/components/other/social-icons.jsx +0 -15
- package/dist/components/other/sonner.jsx +0 -27
- package/dist/components/other/switch.jsx +0 -23
- package/dist/components/other/table.jsx +0 -56
- package/dist/components/other/tabs.jsx +0 -32
- package/dist/components/other/textarea.jsx +0 -19
- package/dist/components/other/toast.jsx +0 -58
- package/dist/components/other/toaster.jsx +0 -31
- package/dist/components/other/toggle-group.jsx +0 -41
- package/dist/components/other/toggle.jsx +0 -39
- package/dist/components/other/tooltip.jsx +0 -24
- package/dist/components/theme-provider.jsx +0 -18
- package/dist/components/types.js +0 -1
- package/dist/hooks/use-toast.js +0 -135
- package/dist/lib/auth-context.jsx +0 -144
- package/dist/lib/constants/about.js +0 -32
- package/dist/lib/constants/adRequest.js +0 -113
- package/dist/lib/constants/contact.js +0 -40
- package/dist/lib/constants/faq.js +0 -36
- package/dist/lib/constants/gallery.js +0 -42
- package/dist/lib/constants/page.js +0 -69
- package/dist/lib/constants/schedule.js +0 -71
- package/dist/lib/google-analytics.jsx +0 -148
- package/dist/lib/utils.js +0 -9
- package/dist/lib/verify-user.js +0 -142
- package/dist/middleware.js +0 -37
- package/dist/tailwind.config.js +0 -86
- package/dist/tsconfig.tsbuildinfo +0 -1
package/app/api/about/route.ts
CHANGED
|
@@ -1,307 +1,307 @@
|
|
|
1
|
-
import { NextRequest, NextResponse } from "next/server";
|
|
2
|
-
import { getAuth } from "@clerk/nextjs/server";
|
|
3
|
-
|
|
4
|
-
export const revalidate = 0;
|
|
5
|
-
|
|
6
|
-
interface StrapiUser {
|
|
7
|
-
id: number;
|
|
8
|
-
username: string;
|
|
9
|
-
email: string;
|
|
10
|
-
businessAdminId?: string;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
interface AboutContent {
|
|
14
|
-
id: number;
|
|
15
|
-
documentId: string;
|
|
16
|
-
title: string;
|
|
17
|
-
description: string;
|
|
18
|
-
about: boolean;
|
|
19
|
-
image?: { url: string; id: number };
|
|
20
|
-
createdAt: string;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const CONTENT_API_URL =
|
|
24
|
-
process.env.STRAPI_CONTENT_API_URL_ABOUT || process.env.STRAPI_CONTENT_API_URL || "";
|
|
25
|
-
const BASE_URL = process.env.STRAPI_API_URL || "";
|
|
26
|
-
const UPLOAD_API_URL = `${BASE_URL}/api/upload`;
|
|
27
|
-
const STRAPI_API_TOKEN = process.env.STRAPI_API_TOKEN || "";
|
|
28
|
-
const STRAPI_USER_LIST_API_URL = process.env.STRAPI_USER_LIST_API_URL || "";
|
|
29
|
-
|
|
30
|
-
export async function GET() {
|
|
31
|
-
try {
|
|
32
|
-
if (!CONTENT_API_URL || !STRAPI_API_TOKEN) {
|
|
33
|
-
console.error(
|
|
34
|
-
"Missing environment variables:",
|
|
35
|
-
!CONTENT_API_URL && "STRAPI_CONTENT_API_URL_ABOUT or STRAPI_CONTENT_API_URL",
|
|
36
|
-
!STRAPI_API_TOKEN && "STRAPI_API_TOKEN"
|
|
37
|
-
);
|
|
38
|
-
return NextResponse.json(
|
|
39
|
-
{ error: "Server configuration error: Missing required environment variables" },
|
|
40
|
-
{ status: 500 }
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
const response = await fetch(
|
|
45
|
-
`${CONTENT_API_URL}?filters[about][$eq]=true&populate=*&fields[0]=title&fields[1]=description&fields[2]=about&fields[3]=createdAt&pagination[pageSize]=100&t=${Date.now()}`,
|
|
46
|
-
{
|
|
47
|
-
headers: {
|
|
48
|
-
"Content-Type": "application/json",
|
|
49
|
-
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
50
|
-
},
|
|
51
|
-
cache: "no-store",
|
|
52
|
-
}
|
|
53
|
-
);
|
|
54
|
-
|
|
55
|
-
if (!response.ok) {
|
|
56
|
-
const errorText = await response.text();
|
|
57
|
-
console.error("Fetch about data failed:", response.status, errorText);
|
|
58
|
-
return NextResponse.json(
|
|
59
|
-
{ error: `Failed to fetch about data: ${errorText}` },
|
|
60
|
-
{ status: response.status }
|
|
61
|
-
);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
const result = await response.json();
|
|
65
|
-
|
|
66
|
-
if (!result.data || result.data.length === 0) {
|
|
67
|
-
console.warn("No about data found with about=true in Strapi response");
|
|
68
|
-
return NextResponse.json({ error: "No about data found with about=true" }, { status: 404 });
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
const aboutData: AboutContent[] = result.data.map((item: any) => {
|
|
72
|
-
const image = item.image;
|
|
73
|
-
const rawUrl = image?.url || "";
|
|
74
|
-
const imageUrl = rawUrl ? (rawUrl.startsWith("http") ? rawUrl : `${BASE_URL}${rawUrl}`) : null;
|
|
75
|
-
return {
|
|
76
|
-
id: item.id,
|
|
77
|
-
documentId: item.documentId,
|
|
78
|
-
title: item.title || "",
|
|
79
|
-
description: item.description || "",
|
|
80
|
-
about: item.about,
|
|
81
|
-
image: imageUrl ? { url: imageUrl, id: image?.id || 0 } : undefined,
|
|
82
|
-
createdAt: item.createdAt,
|
|
83
|
-
};
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
return NextResponse.json({
|
|
87
|
-
data: aboutData[0],
|
|
88
|
-
meta: result.meta,
|
|
89
|
-
});
|
|
90
|
-
} catch (error) {
|
|
91
|
-
console.error("Fetch About Error:", error);
|
|
92
|
-
return NextResponse.json(
|
|
93
|
-
{ error: error instanceof Error ? error.message : "An error occurred while fetching about data" },
|
|
94
|
-
{ status: 500 }
|
|
95
|
-
);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
export async function PUT(request: NextRequest) {
|
|
100
|
-
const { userId } = getAuth(request);
|
|
101
|
-
if (!userId) {
|
|
102
|
-
console.error("PUT /api/about: No userId, returning 401");
|
|
103
|
-
return NextResponse.json({ error: "Unauthorized: No user ID" }, { status: 401 });
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
try {
|
|
107
|
-
if (!CONTENT_API_URL || !STRAPI_API_TOKEN || !STRAPI_USER_LIST_API_URL) {
|
|
108
|
-
console.error(
|
|
109
|
-
"Missing environment variables:",
|
|
110
|
-
!CONTENT_API_URL && "STRAPI_CONTENT_API_URL_ABOUT or STRAPI_CONTENT_API_URL",
|
|
111
|
-
!STRAPI_API_TOKEN && "STRAPI_API_TOKEN",
|
|
112
|
-
!STRAPI_USER_LIST_API_URL && "STRAPI_USER_LIST_API_URL"
|
|
113
|
-
);
|
|
114
|
-
return NextResponse.json(
|
|
115
|
-
{ error: "Server configuration error: Missing required environment variables" },
|
|
116
|
-
{ status: 500 }
|
|
117
|
-
);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
const userResponse = await fetch(
|
|
121
|
-
`${STRAPI_USER_LIST_API_URL}?filters[authId][$eq]=${userId}`,
|
|
122
|
-
{
|
|
123
|
-
headers: {
|
|
124
|
-
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
125
|
-
"Content-Type": "application/json",
|
|
126
|
-
},
|
|
127
|
-
}
|
|
128
|
-
);
|
|
129
|
-
if (!userResponse.ok) {
|
|
130
|
-
const errorText = await userResponse.text();
|
|
131
|
-
console.error("PUT /api/about: Strapi user fetch error:", errorText);
|
|
132
|
-
return NextResponse.json(
|
|
133
|
-
{ error: `User verification failed: ${userResponse.status}` },
|
|
134
|
-
{ status: userResponse.status }
|
|
135
|
-
);
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
const userData = await userResponse.json();
|
|
139
|
-
const strapiUser = userData.data?.find((user: any) => user.authId === userId);
|
|
140
|
-
|
|
141
|
-
if (!strapiUser || !strapiUser.businessAdminId) {
|
|
142
|
-
console.error("PUT /api/about: User not authorized", {
|
|
143
|
-
strapiUser,
|
|
144
|
-
businessAdminId: strapiUser?.businessAdminId,
|
|
145
|
-
});
|
|
146
|
-
return NextResponse.json(
|
|
147
|
-
{ error: "Unauthorized: Only admin can update about data" },
|
|
148
|
-
{ status: 403 }
|
|
149
|
-
);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
const formData = await request.formData();
|
|
153
|
-
const title = formData.get("title") as string | null;
|
|
154
|
-
const description = formData.get("description") as string | null;
|
|
155
|
-
const image = formData.get("image") as File | null;
|
|
156
|
-
|
|
157
|
-
let uploadedFileId: number | null = null;
|
|
158
|
-
if (image) {
|
|
159
|
-
if (!["image/jpeg", "image/png", "image/gif"].includes(image.type)) {
|
|
160
|
-
console.error("PUT /api/about: Invalid image type", { type: image.type });
|
|
161
|
-
return NextResponse.json(
|
|
162
|
-
{ error: "Only JPEG, PNG, or GIF images are allowed" },
|
|
163
|
-
{ status: 400 }
|
|
164
|
-
);
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
const uploadFormData = new FormData();
|
|
168
|
-
uploadFormData.append("files", image);
|
|
169
|
-
|
|
170
|
-
const uploadResponse = await fetch(UPLOAD_API_URL, {
|
|
171
|
-
method: "POST",
|
|
172
|
-
headers: { Authorization: `Bearer ${STRAPI_API_TOKEN}` },
|
|
173
|
-
body: uploadFormData,
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
if (!uploadResponse.ok) {
|
|
177
|
-
const errorText = await uploadResponse.text();
|
|
178
|
-
console.error("PUT /api/about: Upload failed:", uploadResponse.status, errorText);
|
|
179
|
-
return NextResponse.json(
|
|
180
|
-
{ error: `Failed to upload image: ${errorText}` },
|
|
181
|
-
{ status: uploadResponse.status }
|
|
182
|
-
);
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
const uploadResult = await uploadResponse.json();
|
|
186
|
-
uploadedFileId = uploadResult[0]?.id;
|
|
187
|
-
if (!uploadedFileId) {
|
|
188
|
-
console.error("PUT /api/about: Invalid upload response", { uploadResult });
|
|
189
|
-
return NextResponse.json(
|
|
190
|
-
{ error: "Invalid upload response: Missing file ID" },
|
|
191
|
-
{ status: 400 }
|
|
192
|
-
);
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
const fetchResponse = await fetch(
|
|
197
|
-
`${CONTENT_API_URL}?filters[about][$eq]=true&fields[0]=documentId`,
|
|
198
|
-
{
|
|
199
|
-
headers: {
|
|
200
|
-
"Content-Type": "application/json",
|
|
201
|
-
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
202
|
-
},
|
|
203
|
-
}
|
|
204
|
-
);
|
|
205
|
-
|
|
206
|
-
if (!fetchResponse.ok) {
|
|
207
|
-
const errorText = await fetchResponse.text();
|
|
208
|
-
console.error("PUT /api/about: Fetch about data failed:", fetchResponse.status, errorText);
|
|
209
|
-
return NextResponse.json(
|
|
210
|
-
{ error: `Failed to fetch about data: ${errorText}` },
|
|
211
|
-
{ status: fetchResponse.status }
|
|
212
|
-
);
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
const fetchResult = await fetchResponse.json();
|
|
216
|
-
if (!fetchResult.data || fetchResult.data.length === 0) {
|
|
217
|
-
console.warn("PUT /api/about: No about data found with about=true");
|
|
218
|
-
return NextResponse.json({ error: "No about data found with about=true" }, { status: 404 });
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
const documentId = fetchResult.data[0].documentId;
|
|
222
|
-
|
|
223
|
-
const payload: { data: { title?: string; description?: string; about: boolean; image?: number } } = {
|
|
224
|
-
data: { about: true },
|
|
225
|
-
};
|
|
226
|
-
if (title) payload.data.title = title;
|
|
227
|
-
if (description) payload.data.description = description;
|
|
228
|
-
if (uploadedFileId) payload.data.image = uploadedFileId;
|
|
229
|
-
|
|
230
|
-
if (Object.keys(payload.data).length === 1) {
|
|
231
|
-
return NextResponse.json({ data: null });
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
const updateResponse = await fetch(`${CONTENT_API_URL}/${documentId}`, {
|
|
235
|
-
method: "PUT",
|
|
236
|
-
headers: {
|
|
237
|
-
"Content-Type": "application/json",
|
|
238
|
-
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
239
|
-
},
|
|
240
|
-
body: JSON.stringify(payload),
|
|
241
|
-
});
|
|
242
|
-
|
|
243
|
-
if (!updateResponse.ok) {
|
|
244
|
-
const errorText = await updateResponse.text();
|
|
245
|
-
console.error("PUT /api/about: Update failed:", updateResponse.status, errorText);
|
|
246
|
-
return NextResponse.json(
|
|
247
|
-
{ error: `Failed to update about data: ${errorText}` },
|
|
248
|
-
{ status: updateResponse.status }
|
|
249
|
-
);
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
const response = await fetch(
|
|
253
|
-
`${CONTENT_API_URL}?filters[about][$eq]=true&populate=*&fields[0]=title&fields[1]=description&fields[2]=about&fields[3]=createdAt&pagination[pageSize]=100&t=${Date.now()}`,
|
|
254
|
-
{
|
|
255
|
-
headers: {
|
|
256
|
-
"Content-Type": "application/json",
|
|
257
|
-
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
258
|
-
},
|
|
259
|
-
cache: "no-store",
|
|
260
|
-
}
|
|
261
|
-
);
|
|
262
|
-
|
|
263
|
-
if (!response.ok) {
|
|
264
|
-
const errorText = await response.text();
|
|
265
|
-
console.error("PUT /api/about: Refetch failed:", response.status, errorText);
|
|
266
|
-
return NextResponse.json(
|
|
267
|
-
{ error: `Failed to refetch about data: ${errorText}` },
|
|
268
|
-
{ status: response.status }
|
|
269
|
-
);
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
const result = await response.json();
|
|
273
|
-
if (!result.data || result.data.length === 0) {
|
|
274
|
-
console.warn("PUT /api/about: About data not found after update");
|
|
275
|
-
return NextResponse.json({ error: "About data not found after update" }, { status: 404 });
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
const aboutData: AboutContent[] = result.data.map((item: any) => {
|
|
279
|
-
const image = item.image;
|
|
280
|
-
const rawUrl = image?.url || "";
|
|
281
|
-
const imageUrl = rawUrl ? (rawUrl.startsWith("http") ? rawUrl : `${BASE_URL}${rawUrl}`) : null;
|
|
282
|
-
return {
|
|
283
|
-
id: item.id,
|
|
284
|
-
documentId: item.documentId,
|
|
285
|
-
title: item.title || "",
|
|
286
|
-
description: item.description || "",
|
|
287
|
-
about: item.about,
|
|
288
|
-
image: imageUrl ? { url: imageUrl, id: image?.id || 0 } : undefined,
|
|
289
|
-
createdAt: item.createdAt,
|
|
290
|
-
};
|
|
291
|
-
});
|
|
292
|
-
|
|
293
|
-
return NextResponse.json({
|
|
294
|
-
data: aboutData[0],
|
|
295
|
-
meta: result.meta,
|
|
296
|
-
});
|
|
297
|
-
} catch (error) {
|
|
298
|
-
console.error("PUT /api/about: Error:", error);
|
|
299
|
-
return NextResponse.json(
|
|
300
|
-
{
|
|
301
|
-
error:
|
|
302
|
-
error instanceof Error ? error.message : "An error occurred while updating about data",
|
|
303
|
-
},
|
|
304
|
-
{ status: 500 }
|
|
305
|
-
);
|
|
306
|
-
}
|
|
1
|
+
import { NextRequest, NextResponse } from "next/server";
|
|
2
|
+
import { getAuth } from "@clerk/nextjs/server";
|
|
3
|
+
|
|
4
|
+
export const revalidate = 0;
|
|
5
|
+
|
|
6
|
+
interface StrapiUser {
|
|
7
|
+
id: number;
|
|
8
|
+
username: string;
|
|
9
|
+
email: string;
|
|
10
|
+
businessAdminId?: string;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
interface AboutContent {
|
|
14
|
+
id: number;
|
|
15
|
+
documentId: string;
|
|
16
|
+
title: string;
|
|
17
|
+
description: string;
|
|
18
|
+
about: boolean;
|
|
19
|
+
image?: { url: string; id: number };
|
|
20
|
+
createdAt: string;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const CONTENT_API_URL =
|
|
24
|
+
process.env.STRAPI_CONTENT_API_URL_ABOUT || process.env.STRAPI_CONTENT_API_URL || "";
|
|
25
|
+
const BASE_URL = process.env.STRAPI_API_URL || "";
|
|
26
|
+
const UPLOAD_API_URL = `${BASE_URL}/api/upload`;
|
|
27
|
+
const STRAPI_API_TOKEN = process.env.STRAPI_API_TOKEN || "";
|
|
28
|
+
const STRAPI_USER_LIST_API_URL = process.env.STRAPI_USER_LIST_API_URL || "";
|
|
29
|
+
|
|
30
|
+
export async function GET() {
|
|
31
|
+
try {
|
|
32
|
+
if (!CONTENT_API_URL || !STRAPI_API_TOKEN) {
|
|
33
|
+
console.error(
|
|
34
|
+
"Missing environment variables:",
|
|
35
|
+
!CONTENT_API_URL && "STRAPI_CONTENT_API_URL_ABOUT or STRAPI_CONTENT_API_URL",
|
|
36
|
+
!STRAPI_API_TOKEN && "STRAPI_API_TOKEN"
|
|
37
|
+
);
|
|
38
|
+
return NextResponse.json(
|
|
39
|
+
{ error: "Server configuration error: Missing required environment variables" },
|
|
40
|
+
{ status: 500 }
|
|
41
|
+
);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
const response = await fetch(
|
|
45
|
+
`${CONTENT_API_URL}?filters[about][$eq]=true&populate=*&fields[0]=title&fields[1]=description&fields[2]=about&fields[3]=createdAt&pagination[pageSize]=100&t=${Date.now()}`,
|
|
46
|
+
{
|
|
47
|
+
headers: {
|
|
48
|
+
"Content-Type": "application/json",
|
|
49
|
+
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
50
|
+
},
|
|
51
|
+
cache: "no-store",
|
|
52
|
+
}
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
if (!response.ok) {
|
|
56
|
+
const errorText = await response.text();
|
|
57
|
+
console.error("Fetch about data failed:", response.status, errorText);
|
|
58
|
+
return NextResponse.json(
|
|
59
|
+
{ error: `Failed to fetch about data: ${errorText}` },
|
|
60
|
+
{ status: response.status }
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
const result = await response.json();
|
|
65
|
+
|
|
66
|
+
if (!result.data || result.data.length === 0) {
|
|
67
|
+
console.warn("No about data found with about=true in Strapi response");
|
|
68
|
+
return NextResponse.json({ error: "No about data found with about=true" }, { status: 404 });
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const aboutData: AboutContent[] = result.data.map((item: any) => {
|
|
72
|
+
const image = item.image;
|
|
73
|
+
const rawUrl = image?.url || "";
|
|
74
|
+
const imageUrl = rawUrl ? (rawUrl.startsWith("http") ? rawUrl : `${BASE_URL}${rawUrl}`) : null;
|
|
75
|
+
return {
|
|
76
|
+
id: item.id,
|
|
77
|
+
documentId: item.documentId,
|
|
78
|
+
title: item.title || "",
|
|
79
|
+
description: item.description || "",
|
|
80
|
+
about: item.about,
|
|
81
|
+
image: imageUrl ? { url: imageUrl, id: image?.id || 0 } : undefined,
|
|
82
|
+
createdAt: item.createdAt,
|
|
83
|
+
};
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
return NextResponse.json({
|
|
87
|
+
data: aboutData[0],
|
|
88
|
+
meta: result.meta,
|
|
89
|
+
});
|
|
90
|
+
} catch (error) {
|
|
91
|
+
console.error("Fetch About Error:", error);
|
|
92
|
+
return NextResponse.json(
|
|
93
|
+
{ error: error instanceof Error ? error.message : "An error occurred while fetching about data" },
|
|
94
|
+
{ status: 500 }
|
|
95
|
+
);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
export async function PUT(request: NextRequest) {
|
|
100
|
+
const { userId } = getAuth(request);
|
|
101
|
+
if (!userId) {
|
|
102
|
+
console.error("PUT /api/about: No userId, returning 401");
|
|
103
|
+
return NextResponse.json({ error: "Unauthorized: No user ID" }, { status: 401 });
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
try {
|
|
107
|
+
if (!CONTENT_API_URL || !STRAPI_API_TOKEN || !STRAPI_USER_LIST_API_URL) {
|
|
108
|
+
console.error(
|
|
109
|
+
"Missing environment variables:",
|
|
110
|
+
!CONTENT_API_URL && "STRAPI_CONTENT_API_URL_ABOUT or STRAPI_CONTENT_API_URL",
|
|
111
|
+
!STRAPI_API_TOKEN && "STRAPI_API_TOKEN",
|
|
112
|
+
!STRAPI_USER_LIST_API_URL && "STRAPI_USER_LIST_API_URL"
|
|
113
|
+
);
|
|
114
|
+
return NextResponse.json(
|
|
115
|
+
{ error: "Server configuration error: Missing required environment variables" },
|
|
116
|
+
{ status: 500 }
|
|
117
|
+
);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
const userResponse = await fetch(
|
|
121
|
+
`${STRAPI_USER_LIST_API_URL}?filters[authId][$eq]=${userId}`,
|
|
122
|
+
{
|
|
123
|
+
headers: {
|
|
124
|
+
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
125
|
+
"Content-Type": "application/json",
|
|
126
|
+
},
|
|
127
|
+
}
|
|
128
|
+
);
|
|
129
|
+
if (!userResponse.ok) {
|
|
130
|
+
const errorText = await userResponse.text();
|
|
131
|
+
console.error("PUT /api/about: Strapi user fetch error:", errorText);
|
|
132
|
+
return NextResponse.json(
|
|
133
|
+
{ error: `User verification failed: ${userResponse.status}` },
|
|
134
|
+
{ status: userResponse.status }
|
|
135
|
+
);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const userData = await userResponse.json();
|
|
139
|
+
const strapiUser = userData.data?.find((user: any) => user.authId === userId);
|
|
140
|
+
|
|
141
|
+
if (!strapiUser || !strapiUser.businessAdminId) {
|
|
142
|
+
console.error("PUT /api/about: User not authorized", {
|
|
143
|
+
strapiUser,
|
|
144
|
+
businessAdminId: strapiUser?.businessAdminId,
|
|
145
|
+
});
|
|
146
|
+
return NextResponse.json(
|
|
147
|
+
{ error: "Unauthorized: Only admin can update about data" },
|
|
148
|
+
{ status: 403 }
|
|
149
|
+
);
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
const formData = await request.formData();
|
|
153
|
+
const title = formData.get("title") as string | null;
|
|
154
|
+
const description = formData.get("description") as string | null;
|
|
155
|
+
const image = formData.get("image") as File | null;
|
|
156
|
+
|
|
157
|
+
let uploadedFileId: number | null = null;
|
|
158
|
+
if (image) {
|
|
159
|
+
if (!["image/jpeg", "image/png", "image/gif"].includes(image.type)) {
|
|
160
|
+
console.error("PUT /api/about: Invalid image type", { type: image.type });
|
|
161
|
+
return NextResponse.json(
|
|
162
|
+
{ error: "Only JPEG, PNG, or GIF images are allowed" },
|
|
163
|
+
{ status: 400 }
|
|
164
|
+
);
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
const uploadFormData = new FormData();
|
|
168
|
+
uploadFormData.append("files", image);
|
|
169
|
+
|
|
170
|
+
const uploadResponse = await fetch(UPLOAD_API_URL, {
|
|
171
|
+
method: "POST",
|
|
172
|
+
headers: { Authorization: `Bearer ${STRAPI_API_TOKEN}` },
|
|
173
|
+
body: uploadFormData,
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
if (!uploadResponse.ok) {
|
|
177
|
+
const errorText = await uploadResponse.text();
|
|
178
|
+
console.error("PUT /api/about: Upload failed:", uploadResponse.status, errorText);
|
|
179
|
+
return NextResponse.json(
|
|
180
|
+
{ error: `Failed to upload image: ${errorText}` },
|
|
181
|
+
{ status: uploadResponse.status }
|
|
182
|
+
);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
const uploadResult = await uploadResponse.json();
|
|
186
|
+
uploadedFileId = uploadResult[0]?.id;
|
|
187
|
+
if (!uploadedFileId) {
|
|
188
|
+
console.error("PUT /api/about: Invalid upload response", { uploadResult });
|
|
189
|
+
return NextResponse.json(
|
|
190
|
+
{ error: "Invalid upload response: Missing file ID" },
|
|
191
|
+
{ status: 400 }
|
|
192
|
+
);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
const fetchResponse = await fetch(
|
|
197
|
+
`${CONTENT_API_URL}?filters[about][$eq]=true&fields[0]=documentId`,
|
|
198
|
+
{
|
|
199
|
+
headers: {
|
|
200
|
+
"Content-Type": "application/json",
|
|
201
|
+
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
202
|
+
},
|
|
203
|
+
}
|
|
204
|
+
);
|
|
205
|
+
|
|
206
|
+
if (!fetchResponse.ok) {
|
|
207
|
+
const errorText = await fetchResponse.text();
|
|
208
|
+
console.error("PUT /api/about: Fetch about data failed:", fetchResponse.status, errorText);
|
|
209
|
+
return NextResponse.json(
|
|
210
|
+
{ error: `Failed to fetch about data: ${errorText}` },
|
|
211
|
+
{ status: fetchResponse.status }
|
|
212
|
+
);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
const fetchResult = await fetchResponse.json();
|
|
216
|
+
if (!fetchResult.data || fetchResult.data.length === 0) {
|
|
217
|
+
console.warn("PUT /api/about: No about data found with about=true");
|
|
218
|
+
return NextResponse.json({ error: "No about data found with about=true" }, { status: 404 });
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
const documentId = fetchResult.data[0].documentId;
|
|
222
|
+
|
|
223
|
+
const payload: { data: { title?: string; description?: string; about: boolean; image?: number } } = {
|
|
224
|
+
data: { about: true },
|
|
225
|
+
};
|
|
226
|
+
if (title) payload.data.title = title;
|
|
227
|
+
if (description) payload.data.description = description;
|
|
228
|
+
if (uploadedFileId) payload.data.image = uploadedFileId;
|
|
229
|
+
|
|
230
|
+
if (Object.keys(payload.data).length === 1) {
|
|
231
|
+
return NextResponse.json({ data: null });
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
const updateResponse = await fetch(`${CONTENT_API_URL}/${documentId}`, {
|
|
235
|
+
method: "PUT",
|
|
236
|
+
headers: {
|
|
237
|
+
"Content-Type": "application/json",
|
|
238
|
+
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
239
|
+
},
|
|
240
|
+
body: JSON.stringify(payload),
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
if (!updateResponse.ok) {
|
|
244
|
+
const errorText = await updateResponse.text();
|
|
245
|
+
console.error("PUT /api/about: Update failed:", updateResponse.status, errorText);
|
|
246
|
+
return NextResponse.json(
|
|
247
|
+
{ error: `Failed to update about data: ${errorText}` },
|
|
248
|
+
{ status: updateResponse.status }
|
|
249
|
+
);
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
const response = await fetch(
|
|
253
|
+
`${CONTENT_API_URL}?filters[about][$eq]=true&populate=*&fields[0]=title&fields[1]=description&fields[2]=about&fields[3]=createdAt&pagination[pageSize]=100&t=${Date.now()}`,
|
|
254
|
+
{
|
|
255
|
+
headers: {
|
|
256
|
+
"Content-Type": "application/json",
|
|
257
|
+
Authorization: `Bearer ${STRAPI_API_TOKEN}`,
|
|
258
|
+
},
|
|
259
|
+
cache: "no-store",
|
|
260
|
+
}
|
|
261
|
+
);
|
|
262
|
+
|
|
263
|
+
if (!response.ok) {
|
|
264
|
+
const errorText = await response.text();
|
|
265
|
+
console.error("PUT /api/about: Refetch failed:", response.status, errorText);
|
|
266
|
+
return NextResponse.json(
|
|
267
|
+
{ error: `Failed to refetch about data: ${errorText}` },
|
|
268
|
+
{ status: response.status }
|
|
269
|
+
);
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
const result = await response.json();
|
|
273
|
+
if (!result.data || result.data.length === 0) {
|
|
274
|
+
console.warn("PUT /api/about: About data not found after update");
|
|
275
|
+
return NextResponse.json({ error: "About data not found after update" }, { status: 404 });
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
const aboutData: AboutContent[] = result.data.map((item: any) => {
|
|
279
|
+
const image = item.image;
|
|
280
|
+
const rawUrl = image?.url || "";
|
|
281
|
+
const imageUrl = rawUrl ? (rawUrl.startsWith("http") ? rawUrl : `${BASE_URL}${rawUrl}`) : null;
|
|
282
|
+
return {
|
|
283
|
+
id: item.id,
|
|
284
|
+
documentId: item.documentId,
|
|
285
|
+
title: item.title || "",
|
|
286
|
+
description: item.description || "",
|
|
287
|
+
about: item.about,
|
|
288
|
+
image: imageUrl ? { url: imageUrl, id: image?.id || 0 } : undefined,
|
|
289
|
+
createdAt: item.createdAt,
|
|
290
|
+
};
|
|
291
|
+
});
|
|
292
|
+
|
|
293
|
+
return NextResponse.json({
|
|
294
|
+
data: aboutData[0],
|
|
295
|
+
meta: result.meta,
|
|
296
|
+
});
|
|
297
|
+
} catch (error) {
|
|
298
|
+
console.error("PUT /api/about: Error:", error);
|
|
299
|
+
return NextResponse.json(
|
|
300
|
+
{
|
|
301
|
+
error:
|
|
302
|
+
error instanceof Error ? error.message : "An error occurred while updating about data",
|
|
303
|
+
},
|
|
304
|
+
{ status: 500 }
|
|
305
|
+
);
|
|
306
|
+
}
|
|
307
307
|
}
|