@devvistatech/devvista-kit 0.0.10 → 0.0.13
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 +55 -15
- package/app/ClientLayout.tsx +66 -0
- package/app/about/page.tsx +61 -298
- package/app/adRequest/page.tsx +625 -549
- package/app/admin-profile/page.tsx +123 -0
- package/app/analytics/page.tsx +382 -346
- package/app/api/about/route.ts +290 -306
- package/app/api/adRequest/route.ts +547 -567
- package/app/api/analytics/[reportType]/route.ts +274 -337
- package/app/api/bio/route.ts +297 -313
- package/app/api/blog/route.ts +288 -306
- package/app/api/chat/route.ts +14 -14
- package/app/api/contact/route.ts +409 -409
- package/app/api/contacts/route.ts +179 -224
- package/app/api/files/route.ts +415 -429
- package/app/api/gallery-data/route.ts +727 -735
- package/app/api/schedule/route.ts +439 -455
- package/app/api/signup/route.ts +129 -0
- package/app/api/sync-user/route.ts +306 -132
- package/app/api/trial-request/route.ts +297 -297
- package/app/api/verify-admin/route.ts +46 -0
- package/app/blog/[id]/page.tsx +307 -288
- package/app/blog/page.tsx +249 -216
- package/app/contact/page.tsx +284 -284
- package/app/faq/page.tsx +191 -191
- package/app/favicon.ico +0 -0
- package/app/gallery/page.tsx +336 -315
- package/app/globals.css +58 -58
- package/app/layout.tsx +59 -110
- package/app/not-found.tsx +20 -20
- package/app/page.tsx +47 -338
- package/app/products/constants/product.ts +27 -0
- package/app/products/page.tsx +296 -0
- package/app/products/productOne/page.tsx +266 -0
- package/app/products/productTwo/page.tsx +272 -0
- package/app/schedule/page.tsx +698 -660
- package/bin/init.js +207 -219
- package/components/addOns/functional/CalendlyWidget.tsx +107 -107
- package/components/addOns/functional/ClassList.tsx +149 -145
- package/components/addOns/functional/ClassPopup.tsx +398 -398
- package/components/addOns/functional/ContactForm.tsx +284 -284
- package/components/addOns/functional/NewUserAnalytics.tsx +100 -100
- package/components/addOns/functional/ProductList.tsx +1027 -0
- package/components/addOns/functional/aboutSections/AboutSection.tsx +581 -544
- package/components/addOns/functional/aboutSections/constants/aboutSection.ts +70 -65
- package/components/addOns/functional/banner/Banner.tsx +150 -0
- package/components/addOns/functional/banner/BannerDashboard.tsx +283 -0
- package/components/addOns/functional/bioSections/BioEditor.tsx +471 -0
- package/components/addOns/functional/bioSections/constants/bioEditor.ts +36 -0
- package/components/addOns/functional/blogSections/BlogDashboard.tsx +184 -184
- package/components/addOns/functional/blogSections/BlogFormPopUp.tsx +555 -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/{ImageDescCarousel.tsx → carousels/ImageDescCarousel.tsx} +839 -730
- package/components/addOns/functional/carousels/ProductDescCarousel.tsx +1129 -0
- package/components/addOns/functional/{ScheduleCarousel.tsx → carousels/ScheduleCarousel.tsx} +231 -171
- package/components/addOns/functional/carousels/constants.ts/productDescCarousel.ts +197 -0
- package/components/addOns/functional/carousels/constants.ts/scheduleCarousel.ts +20 -0
- package/components/addOns/functional/contactsDashboard/ContactsDashboard.tsx +366 -366
- package/components/addOns/functional/contactsDashboard/constants/contactsDashboard.ts +70 -70
- package/components/addOns/functional/fileUploaders/FileUploader.tsx +437 -0
- package/components/addOns/functional/fileUploaders/constants/fileUploader.ts +45 -0
- package/components/addOns/functional/galleries/GalleryComplex.tsx +1037 -836
- package/components/addOns/functional/galleries/GallerySimple.tsx +537 -509
- package/components/addOns/functional/galleries/ThreeSetGallery.tsx +260 -0
- 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 +276 -262
- package/components/addOns/functional/schedules/ScheduleGridTwo.tsx +299 -294
- package/components/addOns/functional/schedules/ScheduleGridTwoBasic.tsx +293 -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/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/featureSections/FeaturesSection.tsx +74 -0
- package/components/addOns/non-functional/featureSections/constants/featuresSection.ts +30 -0
- package/components/addOns/non-functional/{Heros/HeroSection.tsx → heros/HomeHero.tsx} +144 -142
- package/components/addOns/non-functional/heros/ProductHero.tsx +111 -0
- package/components/addOns/non-functional/heros/constants/hero.ts +62 -0
- 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 +416 -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/hooks/use-toast.ts +188 -188
- package/lib/auth/auth-context.tsx +225 -0
- package/lib/auth/auth-utils.tsx +30 -0
- package/lib/constants/about.ts +34 -34
- package/lib/constants/adRequest.ts +256 -113
- package/lib/constants/admin-profile.ts +12 -0
- 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/google-analytics-tracking.tsx +44 -0
- package/lib/{google-analytics.tsx → google/google-analytics.tsx} +97 -97
- package/lib/types.ts +235 -0
- package/lib/utils/compressImage.tsx +32 -0
- package/middleware.ts +46 -42
- package/netlify.toml +5 -5
- package/next.config.js +10 -10
- package/package.json +117 -116
- package/public/images/test.png +0 -0
- package/tailwind.config.ts +89 -89
- package/tsconfig.json +23 -23
- package/components/addOns/functional/BioEditor.tsx +0 -447
- package/components/addOns/functional/FileUploader.tsx +0 -295
- package/components/addOns/non-functional/FeaturesSection.tsx +0 -63
- package/components/types.ts +0 -50
- 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/lib/auth-context.tsx +0 -131
- package/lib/verify-user.ts +0 -118
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { useState, useEffect, useRef } from "react";
|
|
4
|
+
import Image from "next/image";
|
|
5
|
+
import { UploadedImage } from "@/lib/types";
|
|
6
|
+
import Spinner from "@/components/addOns/non-functional/spinner";
|
|
7
|
+
import { ChevronLeft, ChevronRight } from "lucide-react";
|
|
8
|
+
import { motion } from "framer-motion";
|
|
9
|
+
|
|
10
|
+
interface ThreeSetGalleryProps {
|
|
11
|
+
columns?: "1" | "2" | "3" | "4";
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const ThreeSetGallery = ({ columns = "3" }: ThreeSetGalleryProps) => {
|
|
15
|
+
const [uploadedImages, setUploadedImages] = useState<UploadedImage[]>([]);
|
|
16
|
+
const [isLoading, setIsLoading] = useState(false);
|
|
17
|
+
const [currentSlide, setCurrentSlide] = useState(0);
|
|
18
|
+
const slideshowRef = useRef<HTMLDivElement>(null);
|
|
19
|
+
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
const fetchImages = async () => {
|
|
22
|
+
setIsLoading(true);
|
|
23
|
+
try {
|
|
24
|
+
const response = await fetch(`/api/gallery-data?t=${Date.now()}`, {
|
|
25
|
+
headers: { "Content-Type": "application/json" },
|
|
26
|
+
cache: "no-store",
|
|
27
|
+
});
|
|
28
|
+
if (response.ok) {
|
|
29
|
+
const result = await response.json();
|
|
30
|
+
setUploadedImages(
|
|
31
|
+
result.data.map((image: any) => ({
|
|
32
|
+
id: image.id,
|
|
33
|
+
documentId: image.documentId,
|
|
34
|
+
title: image.title || "Untitled",
|
|
35
|
+
description: image.description || "",
|
|
36
|
+
url: image.url,
|
|
37
|
+
createdAt: image.createdAt,
|
|
38
|
+
category: image.category || "none",
|
|
39
|
+
favorite: image.favorite || false,
|
|
40
|
+
})) || []
|
|
41
|
+
);
|
|
42
|
+
} else {
|
|
43
|
+
console.error("ThreeSetGallery: Gallery API Error", {
|
|
44
|
+
status: response.status,
|
|
45
|
+
statusText: response.statusText,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
} catch (err) {
|
|
49
|
+
console.error("ThreeSetGallery: Fetch Error", err);
|
|
50
|
+
} finally {
|
|
51
|
+
setIsLoading(false);
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
fetchImages();
|
|
55
|
+
}, []);
|
|
56
|
+
|
|
57
|
+
// Filter favorite images
|
|
58
|
+
const favoriteImages = uploadedImages.filter((image) => image.favorite === true);
|
|
59
|
+
|
|
60
|
+
const truncateDescription = (description: string | undefined): string => {
|
|
61
|
+
if (!description) return "No description available".slice(0, 250) + "...";
|
|
62
|
+
return description.length > 250
|
|
63
|
+
? description.slice(0, 250) + "..."
|
|
64
|
+
: description + "...";
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
const goToPrev = () => setCurrentSlide((prev) => (prev - 1 + (favoriteImages.length === 2 ? 1 : favoriteImages.length)) % (favoriteImages.length === 2 ? 1 : favoriteImages.length));
|
|
68
|
+
const goToNext = () => setCurrentSlide((prev) => (prev + 1) % (favoriteImages.length === 2 ? 1 : favoriteImages.length));
|
|
69
|
+
|
|
70
|
+
if (isLoading) {
|
|
71
|
+
return <Spinner />;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
return (
|
|
75
|
+
<section className="w-full" data-testid="three-set-gallery">
|
|
76
|
+
<div className="w-full px-4 sm:px-6">
|
|
77
|
+
{favoriteImages.length === 0 ? (
|
|
78
|
+
<p className="text-center text-gray-700 font-medium text-base sm:text-lg mb-4">
|
|
79
|
+
No content available
|
|
80
|
+
</p>
|
|
81
|
+
) : (
|
|
82
|
+
<>
|
|
83
|
+
{/* Desktop: Grid Layout */}
|
|
84
|
+
<div
|
|
85
|
+
className={`hidden md:grid grid-cols-${columns} gap-4 sm:gap-6`}
|
|
86
|
+
data-testid="desktop-grid"
|
|
87
|
+
>
|
|
88
|
+
{favoriteImages.map((image, index) => (
|
|
89
|
+
<div
|
|
90
|
+
key={image.documentId || `image-${index}`}
|
|
91
|
+
className="relative overflow-hidden group w-full aspect-[4/3] rounded-3xl bg-white/10 backdrop-blur-lg border-2 border-transparent shadow-xl"
|
|
92
|
+
data-testid={`gallery-image-${index}`}
|
|
93
|
+
>
|
|
94
|
+
<Image
|
|
95
|
+
src={image.url}
|
|
96
|
+
alt={
|
|
97
|
+
image.title?.trim() &&
|
|
98
|
+
!image.title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
99
|
+
? image.title
|
|
100
|
+
: `Services Image ${index + 1}`
|
|
101
|
+
}
|
|
102
|
+
fill
|
|
103
|
+
className="object-cover rounded-2xl transition-transform duration-700 group-hover:scale-110"
|
|
104
|
+
quality={85}
|
|
105
|
+
priority={index === 0}
|
|
106
|
+
loading={index === 0 ? "eager" : "lazy"}
|
|
107
|
+
sizes="(max-width: 768px) 100vw, (max-width: 1024px) 50vw, 33vw"
|
|
108
|
+
onError={() => console.error(`ThreeSetGallery: Image failed to load: ${image.url}`)}
|
|
109
|
+
/>
|
|
110
|
+
<div className="absolute inset-0 flex flex-col items-center justify-center bg-black/50 text-white opacity-0 group-hover:opacity-100 transition-opacity duration-300 p-4 sm:p-8">
|
|
111
|
+
<h3 className="text-lg sm:text-xl font-bold">
|
|
112
|
+
{image.title?.trim() &&
|
|
113
|
+
!image.title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
114
|
+
? image.title
|
|
115
|
+
: `Image ${index + 1}`}
|
|
116
|
+
</h3>
|
|
117
|
+
<p className="text-sm sm:text-base">{truncateDescription(image.description)}</p>
|
|
118
|
+
</div>
|
|
119
|
+
</div>
|
|
120
|
+
))}
|
|
121
|
+
</div>
|
|
122
|
+
|
|
123
|
+
{/* Mobile: Carousel Layout */}
|
|
124
|
+
<div
|
|
125
|
+
className={`md:hidden relative h-[40vh] min-h-[400px] sm:h-[50vh] rounded-3xl overflow-hidden bg-white/10 backdrop-blur-lg border-2 border-transparent shadow-xl w-full ${favoriteImages.length === 2 ? '' : 'mx-auto max-w-3xl'} supports-[not(backdrop-filter:blur(10px))]:bg-white/20`}
|
|
126
|
+
data-testid="mobile-carousel"
|
|
127
|
+
ref={slideshowRef}
|
|
128
|
+
>
|
|
129
|
+
{favoriteImages.length === 1 ? (
|
|
130
|
+
<div
|
|
131
|
+
className="relative w-full h-full"
|
|
132
|
+
data-testid="carousel-image-0"
|
|
133
|
+
>
|
|
134
|
+
<Image
|
|
135
|
+
src={favoriteImages[0].url}
|
|
136
|
+
alt={
|
|
137
|
+
favoriteImages[0].title?.trim() &&
|
|
138
|
+
!favoriteImages[0].title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
139
|
+
? favoriteImages[0].title
|
|
140
|
+
: "Services Image 1"
|
|
141
|
+
}
|
|
142
|
+
fill
|
|
143
|
+
className="object-cover rounded-2xl transition-transform duration-700 hover:scale-110"
|
|
144
|
+
quality={85}
|
|
145
|
+
priority
|
|
146
|
+
sizes="100vw"
|
|
147
|
+
onError={() => console.error(`ThreeSetGallery: Image failed to load: ${favoriteImages[0].url}`)}
|
|
148
|
+
/>
|
|
149
|
+
<div className="absolute inset-0 flex flex-col items-center justify-center bg-black/50 text-white opacity-0 hover:opacity-100 transition-opacity duration-300 p-4">
|
|
150
|
+
<h3 className="text-lg font-bold">
|
|
151
|
+
{favoriteImages[0].title?.trim() &&
|
|
152
|
+
!favoriteImages[0].title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
153
|
+
? favoriteImages[0].title
|
|
154
|
+
: "Image 1"}
|
|
155
|
+
</h3>
|
|
156
|
+
<p className="text-sm">{truncateDescription(favoriteImages[0].description)}</p>
|
|
157
|
+
</div>
|
|
158
|
+
</div>
|
|
159
|
+
) : favoriteImages.length === 2 ? (
|
|
160
|
+
<div className="relative w-full h-full flex" data-testid="carousel-two-images">
|
|
161
|
+
{favoriteImages.map((image, index) => (
|
|
162
|
+
<div
|
|
163
|
+
key={image.documentId || `image-${index}`}
|
|
164
|
+
className="relative w-1/2 h-full"
|
|
165
|
+
data-testid={`carousel-image-${index}`}
|
|
166
|
+
>
|
|
167
|
+
<Image
|
|
168
|
+
src={image.url}
|
|
169
|
+
alt={
|
|
170
|
+
image.title?.trim() &&
|
|
171
|
+
!image.title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
172
|
+
? image.title
|
|
173
|
+
: `Services Image ${index + 1}`
|
|
174
|
+
}
|
|
175
|
+
fill
|
|
176
|
+
className="object-cover rounded-2xl transition-transform duration-700 hover:scale-110"
|
|
177
|
+
quality={85}
|
|
178
|
+
priority={index === 0}
|
|
179
|
+
sizes="50vw"
|
|
180
|
+
onError={() => console.error(`ThreeSetGallery: Image failed to load: ${image.url}`)}
|
|
181
|
+
/>
|
|
182
|
+
<div className="absolute inset-0 flex flex-col items-center justify-center bg-black/50 text-white opacity-0 hover:opacity-100 transition-opacity duration-300 p-2">
|
|
183
|
+
<h3 className="text-sm font-bold">
|
|
184
|
+
{image.title?.trim() &&
|
|
185
|
+
!image.title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
186
|
+
? image.title
|
|
187
|
+
: `Image ${index + 1}`}
|
|
188
|
+
</h3>
|
|
189
|
+
<p className="text-xs">{truncateDescription(image.description)}</p>
|
|
190
|
+
</div>
|
|
191
|
+
</div>
|
|
192
|
+
))}
|
|
193
|
+
</div>
|
|
194
|
+
) : (
|
|
195
|
+
<>
|
|
196
|
+
<motion.div
|
|
197
|
+
key={currentSlide}
|
|
198
|
+
initial={{ opacity: 0, x: 50 }}
|
|
199
|
+
animate={{ opacity: 1, x: 0 }}
|
|
200
|
+
exit={{ opacity: 0, x: -50 }}
|
|
201
|
+
transition={{ duration: 0.5, ease: [0.16, 1, 0.3, 1] }}
|
|
202
|
+
className="relative w-full h-full"
|
|
203
|
+
data-testid={`carousel-image-${currentSlide}`}
|
|
204
|
+
>
|
|
205
|
+
<Image
|
|
206
|
+
src={favoriteImages[currentSlide].url}
|
|
207
|
+
alt={
|
|
208
|
+
favoriteImages[currentSlide].title?.trim() &&
|
|
209
|
+
!favoriteImages[currentSlide].title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
210
|
+
? favoriteImages[currentSlide].title
|
|
211
|
+
: `Services Image ${currentSlide + 1}`
|
|
212
|
+
}
|
|
213
|
+
fill
|
|
214
|
+
className="object-cover rounded-2xl transition-transform duration-700 hover:scale-110"
|
|
215
|
+
quality={85}
|
|
216
|
+
priority={currentSlide === 0}
|
|
217
|
+
sizes="100vw"
|
|
218
|
+
onError={() => console.error(`ThreeSetGallery: Image failed to load: ${favoriteImages[currentSlide].url}`)}
|
|
219
|
+
/>
|
|
220
|
+
<div className="absolute inset-0 flex flex-col items-center justify-center bg-black/50 text-white opacity-0 hover:opacity-100 transition-opacity duration-300 p-4">
|
|
221
|
+
<h3 className="text-lg font-bold">
|
|
222
|
+
{favoriteImages[currentSlide].title?.trim() &&
|
|
223
|
+
!favoriteImages[currentSlide].title.match(/Image \d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z/)
|
|
224
|
+
? favoriteImages[currentSlide].title
|
|
225
|
+
: `Image ${currentSlide + 1}`}
|
|
226
|
+
</h3>
|
|
227
|
+
<p className="text-sm">{truncateDescription(favoriteImages[currentSlide].description)}</p>
|
|
228
|
+
</div>
|
|
229
|
+
</motion.div>
|
|
230
|
+
<button
|
|
231
|
+
onClick={(e) => {
|
|
232
|
+
e.stopPropagation();
|
|
233
|
+
goToPrev();
|
|
234
|
+
}}
|
|
235
|
+
className="absolute left-2 top-1/2 transform -translate-y-1/2 bg-gray-800/60 hover:bg-gray-800/80 text-white p-2 rounded-full transition-colors duration-300"
|
|
236
|
+
aria-label="Previous slide"
|
|
237
|
+
>
|
|
238
|
+
<ChevronLeft className="h-6 w-6" />
|
|
239
|
+
</button>
|
|
240
|
+
<button
|
|
241
|
+
onClick={(e) => {
|
|
242
|
+
e.stopPropagation();
|
|
243
|
+
goToNext();
|
|
244
|
+
}}
|
|
245
|
+
className="absolute right-2 top-1/2 transform -translate-y-1/2 bg-gray-800/60 hover:bg-gray-800/80 text-white p-2 rounded-full transition-colors duration-300"
|
|
246
|
+
aria-label="Next slide"
|
|
247
|
+
>
|
|
248
|
+
<ChevronRight className="h-6 w-6" />
|
|
249
|
+
</button>
|
|
250
|
+
</>
|
|
251
|
+
)}
|
|
252
|
+
</div>
|
|
253
|
+
</>
|
|
254
|
+
)}
|
|
255
|
+
</div>
|
|
256
|
+
</section>
|
|
257
|
+
);
|
|
258
|
+
};
|
|
259
|
+
|
|
260
|
+
export default ThreeSetGallery;
|
|
@@ -1,107 +1,107 @@
|
|
|
1
|
-
// components/addOns/functional/galleries/constants/galleryComplex.ts
|
|
2
|
-
// Constants for hardcoded text in GalleryComplex.tsx, organized by purpose
|
|
3
|
-
|
|
4
|
-
export const GALLERY_COMPLEX = {
|
|
5
|
-
// UI Text for GalleryComplex
|
|
6
|
-
UI: {
|
|
7
|
-
// TabsTrigger value for photos tab (capitalized in UI)
|
|
8
|
-
PHOTOS_TAB: "Photos",
|
|
9
|
-
// TabsTrigger value for videos tab (capitalized in UI)
|
|
10
|
-
VIDEOS_TAB: "Videos",
|
|
11
|
-
// Sub-tab value for all images (capitalized in UI)
|
|
12
|
-
ALL_SUB_TAB: "All",
|
|
13
|
-
// Sub-tab value for indoor images (capitalized in UI)
|
|
14
|
-
INDOOR_SUB_TAB: "Indoor",
|
|
15
|
-
// Sub-tab value for outdoor images (capitalized in UI)
|
|
16
|
-
OUTDOOR_SUB_TAB: "Outdoor",
|
|
17
|
-
// Sub-tab value for commercial images (capitalized in UI)
|
|
18
|
-
COMMERCIAL_SUB_TAB: "Commercial",
|
|
19
|
-
// Text when no images exist
|
|
20
|
-
NO_IMAGES_MESSAGE: "No images available.",
|
|
21
|
-
// Text when loading
|
|
22
|
-
LOADING_MESSAGE: "Loading...",
|
|
23
|
-
// Text when admin is logged in
|
|
24
|
-
ADMIN_LOGGED_IN_MESSAGE: "You are logged in as an admin.",
|
|
25
|
-
// Default alt text for images
|
|
26
|
-
DEFAULT_IMAGE_ALT: "Gallery image",
|
|
27
|
-
// Delete confirmation modal heading
|
|
28
|
-
DELETE_MODAL_HEADING: "Confirm Deletion",
|
|
29
|
-
// Delete confirmation message
|
|
30
|
-
DELETE_CONFIRMATION_MESSAGE: "Are you sure you want to delete this image? This action cannot be undone.",
|
|
31
|
-
// Upload modal heading
|
|
32
|
-
UPLOAD_MODAL_HEADING: "Upload New Image",
|
|
33
|
-
// Default text for file input label
|
|
34
|
-
CHOOSE_IMAGE_TEXT: "Choose an image",
|
|
35
|
-
// Placeholder for title input in edit/upload forms
|
|
36
|
-
TITLE_PLACEHOLDER: "Image title (optional)",
|
|
37
|
-
// Placeholder for description textarea in edit/upload forms
|
|
38
|
-
DESCRIPTION_PLACEHOLDER: "Image description (optional)",
|
|
39
|
-
// Category option for none
|
|
40
|
-
CATEGORY_NONE: "None",
|
|
41
|
-
// Category option for indoor
|
|
42
|
-
CATEGORY_INDOOR: "Indoor",
|
|
43
|
-
// Category option for outdoor
|
|
44
|
-
CATEGORY_OUTDOOR: "Outdoor",
|
|
45
|
-
// Category option for commercial
|
|
46
|
-
CATEGORY_COMMERCIAL: "Commercial",
|
|
47
|
-
// Edit modal heading
|
|
48
|
-
EDIT_MODAL_HEADING: "Edit Image",
|
|
49
|
-
// No videos available message
|
|
50
|
-
NO_VIDEOS_MESSAGE: "No videos are available",
|
|
51
|
-
// Video titles for video cards
|
|
52
|
-
VIDEO_TITLES: [
|
|
53
|
-
"Lorem ipsum dolor sit ame",
|
|
54
|
-
"Lorem ipsum dolor sit ame",
|
|
55
|
-
"Lorem ipsum dolor sit ame",
|
|
56
|
-
"Lorem ipsum dolor sit ame",
|
|
57
|
-
"Lorem ipsum dolor sit ame",
|
|
58
|
-
"Lorem ipsum dolor sit ame",
|
|
59
|
-
"Lorem ipsum dolor sit ame",
|
|
60
|
-
"Lorem ipsum dolor sit ame",
|
|
61
|
-
"Lorem ipsum dolor sit ame",
|
|
62
|
-
"Lorem ipsum dolor sit ame",
|
|
63
|
-
"Lorem ipsum dolor sit ame",
|
|
64
|
-
"Lorem ipsum dolor sit ame",
|
|
65
|
-
"Lorem ipsum dolor sit ame",
|
|
66
|
-
"Lorem ipsum dolor sit ame",
|
|
67
|
-
"Lorem ipsum dolor sit ame",
|
|
68
|
-
"Lorem ipsum dolor sit ame",
|
|
69
|
-
],
|
|
70
|
-
},
|
|
71
|
-
// Button Text for GalleryComplex
|
|
72
|
-
BUTTONS: {
|
|
73
|
-
// ActionButton text for opening upload modal
|
|
74
|
-
UPLOAD_IMAGE_BUTTON: "Upload New Image",
|
|
75
|
-
// ActionButton text for loading more images
|
|
76
|
-
LOAD_MORE_BUTTON: "Load More",
|
|
77
|
-
// DeleteButton text when loading
|
|
78
|
-
DELETING_BUTTON: "Deleting...",
|
|
79
|
-
// DeleteButton text
|
|
80
|
-
DELETE_BUTTON: "Delete",
|
|
81
|
-
// SubmitButton text when loading in upload form
|
|
82
|
-
UPLOADING_BUTTON: "Uploading...",
|
|
83
|
-
// SubmitButton text in upload form
|
|
84
|
-
UPLOAD_BUTTON: "Upload",
|
|
85
|
-
// SubmitButton text when loading in edit form
|
|
86
|
-
SAVING_BUTTON: "Saving...",
|
|
87
|
-
// SubmitButton text in edit form
|
|
88
|
-
SAVE_BUTTON: "Save",
|
|
89
|
-
},
|
|
90
|
-
// Error Messages for GalleryComplex
|
|
91
|
-
ERRORS: {
|
|
92
|
-
// Error when non-admin tries to delete
|
|
93
|
-
UNAUTHORIZED_DELETE: "Unauthorized: Only admins can delete images",
|
|
94
|
-
// Error when non-admin tries to edit
|
|
95
|
-
UNAUTHORIZED_EDIT: "Unauthorized: Only admins can edit images",
|
|
96
|
-
// Error when token is missing or invalid
|
|
97
|
-
AUTHENTICATION_ERROR: "Authentication error. Please log in again.",
|
|
98
|
-
// Error when edit fails with status code
|
|
99
|
-
EDIT_FAILED_STATUS: "Failed to update image: ${response.status}",
|
|
100
|
-
// Generic error when edit fails
|
|
101
|
-
EDIT_FAILED: "Failed to update image",
|
|
102
|
-
// Error when non-admin tries to upload
|
|
103
|
-
UNAUTHORIZED_UPLOAD: "Unauthorized: Only admins can Upload New Images",
|
|
104
|
-
// Error when upload fails
|
|
105
|
-
UPLOAD_FAILED: "Failed to Upload New Image",
|
|
106
|
-
},
|
|
1
|
+
// components/addOns/functional/galleries/constants/galleryComplex.ts
|
|
2
|
+
// Constants for hardcoded text in GalleryComplex.tsx, organized by purpose
|
|
3
|
+
|
|
4
|
+
export const GALLERY_COMPLEX = {
|
|
5
|
+
// UI Text for GalleryComplex
|
|
6
|
+
UI: {
|
|
7
|
+
// TabsTrigger value for photos tab (capitalized in UI)
|
|
8
|
+
PHOTOS_TAB: "Photos",
|
|
9
|
+
// TabsTrigger value for videos tab (capitalized in UI)
|
|
10
|
+
VIDEOS_TAB: "Videos",
|
|
11
|
+
// Sub-tab value for all images (capitalized in UI)
|
|
12
|
+
ALL_SUB_TAB: "All",
|
|
13
|
+
// Sub-tab value for indoor images (capitalized in UI)
|
|
14
|
+
INDOOR_SUB_TAB: "Indoor",
|
|
15
|
+
// Sub-tab value for outdoor images (capitalized in UI)
|
|
16
|
+
OUTDOOR_SUB_TAB: "Outdoor",
|
|
17
|
+
// Sub-tab value for commercial images (capitalized in UI)
|
|
18
|
+
COMMERCIAL_SUB_TAB: "Commercial",
|
|
19
|
+
// Text when no images exist
|
|
20
|
+
NO_IMAGES_MESSAGE: "No images available.",
|
|
21
|
+
// Text when loading
|
|
22
|
+
LOADING_MESSAGE: "Loading...",
|
|
23
|
+
// Text when admin is logged in
|
|
24
|
+
ADMIN_LOGGED_IN_MESSAGE: "You are logged in as an admin.",
|
|
25
|
+
// Default alt text for images
|
|
26
|
+
DEFAULT_IMAGE_ALT: "Gallery image",
|
|
27
|
+
// Delete confirmation modal heading
|
|
28
|
+
DELETE_MODAL_HEADING: "Confirm Deletion",
|
|
29
|
+
// Delete confirmation message
|
|
30
|
+
DELETE_CONFIRMATION_MESSAGE: "Are you sure you want to delete this image? This action cannot be undone.",
|
|
31
|
+
// Upload modal heading
|
|
32
|
+
UPLOAD_MODAL_HEADING: "Upload New Image",
|
|
33
|
+
// Default text for file input label
|
|
34
|
+
CHOOSE_IMAGE_TEXT: "Choose an image",
|
|
35
|
+
// Placeholder for title input in edit/upload forms
|
|
36
|
+
TITLE_PLACEHOLDER: "Image title (optional)",
|
|
37
|
+
// Placeholder for description textarea in edit/upload forms
|
|
38
|
+
DESCRIPTION_PLACEHOLDER: "Image description (optional)",
|
|
39
|
+
// Category option for none
|
|
40
|
+
CATEGORY_NONE: "None",
|
|
41
|
+
// Category option for indoor
|
|
42
|
+
CATEGORY_INDOOR: "Indoor",
|
|
43
|
+
// Category option for outdoor
|
|
44
|
+
CATEGORY_OUTDOOR: "Outdoor",
|
|
45
|
+
// Category option for commercial
|
|
46
|
+
CATEGORY_COMMERCIAL: "Commercial",
|
|
47
|
+
// Edit modal heading
|
|
48
|
+
EDIT_MODAL_HEADING: "Edit Image",
|
|
49
|
+
// No videos available message
|
|
50
|
+
NO_VIDEOS_MESSAGE: "No videos are available",
|
|
51
|
+
// Video titles for video cards
|
|
52
|
+
VIDEO_TITLES: [
|
|
53
|
+
"Lorem ipsum dolor sit ame",
|
|
54
|
+
"Lorem ipsum dolor sit ame",
|
|
55
|
+
"Lorem ipsum dolor sit ame",
|
|
56
|
+
"Lorem ipsum dolor sit ame",
|
|
57
|
+
"Lorem ipsum dolor sit ame",
|
|
58
|
+
"Lorem ipsum dolor sit ame",
|
|
59
|
+
"Lorem ipsum dolor sit ame",
|
|
60
|
+
"Lorem ipsum dolor sit ame",
|
|
61
|
+
"Lorem ipsum dolor sit ame",
|
|
62
|
+
"Lorem ipsum dolor sit ame",
|
|
63
|
+
"Lorem ipsum dolor sit ame",
|
|
64
|
+
"Lorem ipsum dolor sit ame",
|
|
65
|
+
"Lorem ipsum dolor sit ame",
|
|
66
|
+
"Lorem ipsum dolor sit ame",
|
|
67
|
+
"Lorem ipsum dolor sit ame",
|
|
68
|
+
"Lorem ipsum dolor sit ame",
|
|
69
|
+
],
|
|
70
|
+
},
|
|
71
|
+
// Button Text for GalleryComplex
|
|
72
|
+
BUTTONS: {
|
|
73
|
+
// ActionButton text for opening upload modal
|
|
74
|
+
UPLOAD_IMAGE_BUTTON: "Upload New Image",
|
|
75
|
+
// ActionButton text for loading more images
|
|
76
|
+
LOAD_MORE_BUTTON: "Load More",
|
|
77
|
+
// DeleteButton text when loading
|
|
78
|
+
DELETING_BUTTON: "Deleting...",
|
|
79
|
+
// DeleteButton text
|
|
80
|
+
DELETE_BUTTON: "Delete",
|
|
81
|
+
// SubmitButton text when loading in upload form
|
|
82
|
+
UPLOADING_BUTTON: "Uploading...",
|
|
83
|
+
// SubmitButton text in upload form
|
|
84
|
+
UPLOAD_BUTTON: "Upload",
|
|
85
|
+
// SubmitButton text when loading in edit form
|
|
86
|
+
SAVING_BUTTON: "Saving...",
|
|
87
|
+
// SubmitButton text in edit form
|
|
88
|
+
SAVE_BUTTON: "Save",
|
|
89
|
+
},
|
|
90
|
+
// Error Messages for GalleryComplex
|
|
91
|
+
ERRORS: {
|
|
92
|
+
// Error when non-admin tries to delete
|
|
93
|
+
UNAUTHORIZED_DELETE: "Unauthorized: Only admins can delete images",
|
|
94
|
+
// Error when non-admin tries to edit
|
|
95
|
+
UNAUTHORIZED_EDIT: "Unauthorized: Only admins can edit images",
|
|
96
|
+
// Error when token is missing or invalid
|
|
97
|
+
AUTHENTICATION_ERROR: "Authentication error. Please log in again.",
|
|
98
|
+
// Error when edit fails with status code
|
|
99
|
+
EDIT_FAILED_STATUS: "Failed to update image: ${response.status}",
|
|
100
|
+
// Generic error when edit fails
|
|
101
|
+
EDIT_FAILED: "Failed to update image",
|
|
102
|
+
// Error when non-admin tries to upload
|
|
103
|
+
UNAUTHORIZED_UPLOAD: "Unauthorized: Only admins can Upload New Images",
|
|
104
|
+
// Error when upload fails
|
|
105
|
+
UPLOAD_FAILED: "Failed to Upload New Image",
|
|
106
|
+
},
|
|
107
107
|
};
|
|
@@ -1,77 +1,77 @@
|
|
|
1
|
-
// components/addOns/functional/galleries/constants/gallerySimple.ts
|
|
2
|
-
// Constants for hardcoded text in GallerySimple.tsx, organized by purpose
|
|
3
|
-
|
|
4
|
-
export const GALLERY_SIMPLE = {
|
|
5
|
-
// UI Text for GallerySimple
|
|
6
|
-
UI: {
|
|
7
|
-
// TabsTrigger text for photos tab
|
|
8
|
-
PHOTOS_TAB: "Photos",
|
|
9
|
-
// TabsTrigger text for videos tab
|
|
10
|
-
VIDEOS_TAB: "Videos",
|
|
11
|
-
// Text when no images exist
|
|
12
|
-
NO_IMAGES_MESSAGE: "No images available.",
|
|
13
|
-
// Text when loading
|
|
14
|
-
LOADING_MESSAGE: "Loading...",
|
|
15
|
-
// Text when admin is logged in
|
|
16
|
-
ADMIN_LOGGED_IN_MESSAGE: "You are logged in as an admin.",
|
|
17
|
-
// Default alt text for images
|
|
18
|
-
DEFAULT_IMAGE_ALT: "Gallery image",
|
|
19
|
-
// Delete confirmation modal heading
|
|
20
|
-
DELETE_MODAL_HEADING: "Confirm Deletion",
|
|
21
|
-
// Delete confirmation message
|
|
22
|
-
DELETE_CONFIRMATION_MESSAGE: "Are you sure you want to delete this image? This action cannot be undone.",
|
|
23
|
-
// Upload modal heading
|
|
24
|
-
UPLOAD_MODAL_HEADING: "Upload New Image",
|
|
25
|
-
// Default text for file input label
|
|
26
|
-
CHOOSE_IMAGE_TEXT: "Choose an image",
|
|
27
|
-
// TrashIconButton aria-label template
|
|
28
|
-
DELETE_BUTTON_ARIA: "Delete image ${image.title || image.documentId}",
|
|
29
|
-
// No videos available message
|
|
30
|
-
NO_VIDEOS_MESSAGE: "No videos are available",
|
|
31
|
-
// Video titles for video cards
|
|
32
|
-
VIDEO_TITLES: [
|
|
33
|
-
"Lorem ipsum dolor sit ame",
|
|
34
|
-
"Lorem ipsum dolor sit ame",
|
|
35
|
-
"Lorem ipsum dolor sit ame",
|
|
36
|
-
"Lorem ipsum dolor sit ame",
|
|
37
|
-
"Lorem ipsum dolor sit ame",
|
|
38
|
-
"Lorem ipsum dolor sit ame",
|
|
39
|
-
"Lorem ipsum dolor sit ame",
|
|
40
|
-
"Lorem ipsum dolor sit ame",
|
|
41
|
-
"Lorem ipsum dolor sit ame",
|
|
42
|
-
"Lorem ipsum dolor sit ame",
|
|
43
|
-
"Lorem ipsum dolor sit ame",
|
|
44
|
-
"Lorem ipsum dolor sit ame",
|
|
45
|
-
"Lorem ipsum dolor sit ame",
|
|
46
|
-
"Lorem ipsum dolor sit ame",
|
|
47
|
-
"Lorem ipsum dolor sit ame",
|
|
48
|
-
"Lorem ipsum dolor sit ame",
|
|
49
|
-
],
|
|
50
|
-
},
|
|
51
|
-
// Button Text for GallerySimple
|
|
52
|
-
BUTTONS: {
|
|
53
|
-
// ActionButton text for opening upload modal
|
|
54
|
-
UPLOAD_IMAGE_BUTTON: "Upload New Image",
|
|
55
|
-
// ActionButton text for loading more images
|
|
56
|
-
LOAD_MORE_BUTTON: "Load More",
|
|
57
|
-
// DeleteButton text when loading
|
|
58
|
-
DELETING_BUTTON: "Deleting...",
|
|
59
|
-
// DeleteButton text
|
|
60
|
-
DELETE_BUTTON: "Delete",
|
|
61
|
-
// SubmitButton text when loading
|
|
62
|
-
UPLOADING_BUTTON: "Uploading...",
|
|
63
|
-
// SubmitButton text
|
|
64
|
-
UPLOAD_BUTTON: "Upload",
|
|
65
|
-
},
|
|
66
|
-
// Error Messages for GallerySimple
|
|
67
|
-
ERRORS: {
|
|
68
|
-
// Error when non-admin tries to delete
|
|
69
|
-
UNAUTHORIZED_DELETE: "Unauthorized: Only admins can delete images",
|
|
70
|
-
// Error when no file is selected
|
|
71
|
-
INVALID_FILE: "Please select a valid image file",
|
|
72
|
-
// Error when non-admin tries to upload
|
|
73
|
-
UNAUTHORIZED_UPLOAD: "Unauthorized: Only admins can Upload New Images",
|
|
74
|
-
// Error when upload fails
|
|
75
|
-
UPLOAD_FAILED: "Failed to Upload New Image",
|
|
76
|
-
},
|
|
1
|
+
// components/addOns/functional/galleries/constants/gallerySimple.ts
|
|
2
|
+
// Constants for hardcoded text in GallerySimple.tsx, organized by purpose
|
|
3
|
+
|
|
4
|
+
export const GALLERY_SIMPLE = {
|
|
5
|
+
// UI Text for GallerySimple
|
|
6
|
+
UI: {
|
|
7
|
+
// TabsTrigger text for photos tab
|
|
8
|
+
PHOTOS_TAB: "Photos",
|
|
9
|
+
// TabsTrigger text for videos tab
|
|
10
|
+
VIDEOS_TAB: "Videos",
|
|
11
|
+
// Text when no images exist
|
|
12
|
+
NO_IMAGES_MESSAGE: "No images available.",
|
|
13
|
+
// Text when loading
|
|
14
|
+
LOADING_MESSAGE: "Loading...",
|
|
15
|
+
// Text when admin is logged in
|
|
16
|
+
ADMIN_LOGGED_IN_MESSAGE: "You are logged in as an admin.",
|
|
17
|
+
// Default alt text for images
|
|
18
|
+
DEFAULT_IMAGE_ALT: "Gallery image",
|
|
19
|
+
// Delete confirmation modal heading
|
|
20
|
+
DELETE_MODAL_HEADING: "Confirm Deletion",
|
|
21
|
+
// Delete confirmation message
|
|
22
|
+
DELETE_CONFIRMATION_MESSAGE: "Are you sure you want to delete this image? This action cannot be undone.",
|
|
23
|
+
// Upload modal heading
|
|
24
|
+
UPLOAD_MODAL_HEADING: "Upload New Image",
|
|
25
|
+
// Default text for file input label
|
|
26
|
+
CHOOSE_IMAGE_TEXT: "Choose an image",
|
|
27
|
+
// TrashIconButton aria-label template
|
|
28
|
+
DELETE_BUTTON_ARIA: "Delete image ${image.title || image.documentId}",
|
|
29
|
+
// No videos available message
|
|
30
|
+
NO_VIDEOS_MESSAGE: "No videos are available",
|
|
31
|
+
// Video titles for video cards
|
|
32
|
+
VIDEO_TITLES: [
|
|
33
|
+
"Lorem ipsum dolor sit ame",
|
|
34
|
+
"Lorem ipsum dolor sit ame",
|
|
35
|
+
"Lorem ipsum dolor sit ame",
|
|
36
|
+
"Lorem ipsum dolor sit ame",
|
|
37
|
+
"Lorem ipsum dolor sit ame",
|
|
38
|
+
"Lorem ipsum dolor sit ame",
|
|
39
|
+
"Lorem ipsum dolor sit ame",
|
|
40
|
+
"Lorem ipsum dolor sit ame",
|
|
41
|
+
"Lorem ipsum dolor sit ame",
|
|
42
|
+
"Lorem ipsum dolor sit ame",
|
|
43
|
+
"Lorem ipsum dolor sit ame",
|
|
44
|
+
"Lorem ipsum dolor sit ame",
|
|
45
|
+
"Lorem ipsum dolor sit ame",
|
|
46
|
+
"Lorem ipsum dolor sit ame",
|
|
47
|
+
"Lorem ipsum dolor sit ame",
|
|
48
|
+
"Lorem ipsum dolor sit ame",
|
|
49
|
+
],
|
|
50
|
+
},
|
|
51
|
+
// Button Text for GallerySimple
|
|
52
|
+
BUTTONS: {
|
|
53
|
+
// ActionButton text for opening upload modal
|
|
54
|
+
UPLOAD_IMAGE_BUTTON: "Upload New Image",
|
|
55
|
+
// ActionButton text for loading more images
|
|
56
|
+
LOAD_MORE_BUTTON: "Load More",
|
|
57
|
+
// DeleteButton text when loading
|
|
58
|
+
DELETING_BUTTON: "Deleting...",
|
|
59
|
+
// DeleteButton text
|
|
60
|
+
DELETE_BUTTON: "Delete",
|
|
61
|
+
// SubmitButton text when loading
|
|
62
|
+
UPLOADING_BUTTON: "Uploading...",
|
|
63
|
+
// SubmitButton text
|
|
64
|
+
UPLOAD_BUTTON: "Upload",
|
|
65
|
+
},
|
|
66
|
+
// Error Messages for GallerySimple
|
|
67
|
+
ERRORS: {
|
|
68
|
+
// Error when non-admin tries to delete
|
|
69
|
+
UNAUTHORIZED_DELETE: "Unauthorized: Only admins can delete images",
|
|
70
|
+
// Error when no file is selected
|
|
71
|
+
INVALID_FILE: "Please select a valid image file",
|
|
72
|
+
// Error when non-admin tries to upload
|
|
73
|
+
UNAUTHORIZED_UPLOAD: "Unauthorized: Only admins can Upload New Images",
|
|
74
|
+
// Error when upload fails
|
|
75
|
+
UPLOAD_FAILED: "Failed to Upload New Image",
|
|
76
|
+
},
|
|
77
77
|
};
|