@xscriptor/xcomponents 0.1.0

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 (84) hide show
  1. package/CODE_OF_CONDUCT.md +35 -0
  2. package/CONTRIBUTING.md +64 -0
  3. package/LICENSE +21 -0
  4. package/README.md +127 -0
  5. package/SECURITY.md +25 -0
  6. package/dist/chunk-2OAXRRVQ.mjs +150 -0
  7. package/dist/chunk-2OAXRRVQ.mjs.map +1 -0
  8. package/dist/chunk-42XPBYTL.mjs +186 -0
  9. package/dist/chunk-42XPBYTL.mjs.map +1 -0
  10. package/dist/chunk-5G4P2E76.mjs +66 -0
  11. package/dist/chunk-5G4P2E76.mjs.map +1 -0
  12. package/dist/chunk-FZRTAML3.mjs +1 -0
  13. package/dist/chunk-FZRTAML3.mjs.map +1 -0
  14. package/dist/chunk-NY22GB3E.mjs +311 -0
  15. package/dist/chunk-NY22GB3E.mjs.map +1 -0
  16. package/dist/chunk-QCMWPIG7.mjs +320 -0
  17. package/dist/chunk-QCMWPIG7.mjs.map +1 -0
  18. package/dist/chunk-U27ZVCP7.mjs +247 -0
  19. package/dist/chunk-U27ZVCP7.mjs.map +1 -0
  20. package/dist/components/content/index.css +132 -0
  21. package/dist/components/content/index.css.map +1 -0
  22. package/dist/components/content/index.d.mts +17 -0
  23. package/dist/components/content/index.d.ts +17 -0
  24. package/dist/components/content/index.js +102 -0
  25. package/dist/components/content/index.js.map +1 -0
  26. package/dist/components/content/index.mjs +7 -0
  27. package/dist/components/content/index.mjs.map +1 -0
  28. package/dist/components/forms/index.css +307 -0
  29. package/dist/components/forms/index.css.map +1 -0
  30. package/dist/components/forms/index.d.mts +68 -0
  31. package/dist/components/forms/index.d.ts +68 -0
  32. package/dist/components/forms/index.js +357 -0
  33. package/dist/components/forms/index.js.map +1 -0
  34. package/dist/components/forms/index.mjs +9 -0
  35. package/dist/components/forms/index.mjs.map +1 -0
  36. package/dist/components/gallery/index.css +229 -0
  37. package/dist/components/gallery/index.css.map +1 -0
  38. package/dist/components/gallery/index.d.mts +29 -0
  39. package/dist/components/gallery/index.d.ts +29 -0
  40. package/dist/components/gallery/index.js +187 -0
  41. package/dist/components/gallery/index.js.map +1 -0
  42. package/dist/components/gallery/index.mjs +9 -0
  43. package/dist/components/gallery/index.mjs.map +1 -0
  44. package/dist/components/index.css +1181 -0
  45. package/dist/components/index.css.map +1 -0
  46. package/dist/components/index.d.mts +8 -0
  47. package/dist/components/index.d.ts +8 -0
  48. package/dist/components/index.js +1317 -0
  49. package/dist/components/index.js.map +1 -0
  50. package/dist/components/index.mjs +50 -0
  51. package/dist/components/index.mjs.map +1 -0
  52. package/dist/components/layout/index.css +168 -0
  53. package/dist/components/layout/index.css.map +1 -0
  54. package/dist/components/layout/index.d.mts +55 -0
  55. package/dist/components/layout/index.d.ts +55 -0
  56. package/dist/components/layout/index.js +224 -0
  57. package/dist/components/layout/index.js.map +1 -0
  58. package/dist/components/layout/index.mjs +11 -0
  59. package/dist/components/layout/index.mjs.map +1 -0
  60. package/dist/components/navigation/index.css +229 -0
  61. package/dist/components/navigation/index.css.map +1 -0
  62. package/dist/components/navigation/index.d.mts +76 -0
  63. package/dist/components/navigation/index.d.ts +76 -0
  64. package/dist/components/navigation/index.js +347 -0
  65. package/dist/components/navigation/index.js.map +1 -0
  66. package/dist/components/navigation/index.mjs +7 -0
  67. package/dist/components/navigation/index.mjs.map +1 -0
  68. package/dist/components/social/index.css +116 -0
  69. package/dist/components/social/index.css.map +1 -0
  70. package/dist/components/social/index.d.mts +55 -0
  71. package/dist/components/social/index.d.ts +55 -0
  72. package/dist/components/social/index.js +280 -0
  73. package/dist/components/social/index.js.map +1 -0
  74. package/dist/components/social/index.mjs +21 -0
  75. package/dist/components/social/index.mjs.map +1 -0
  76. package/dist/index.css +1181 -0
  77. package/dist/index.css.map +1 -0
  78. package/dist/index.d.mts +8 -0
  79. package/dist/index.d.ts +8 -0
  80. package/dist/index.js +1317 -0
  81. package/dist/index.js.map +1 -0
  82. package/dist/index.mjs +50 -0
  83. package/dist/index.mjs.map +1 -0
  84. package/package.json +86 -0
@@ -0,0 +1,229 @@
1
+ /* src/components/gallery/xmicrogallerytext/XMicroGalleryText.module.css */
2
+ .container {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: 2rem;
6
+ width: 100%;
7
+ align-items: center;
8
+ margin: 2rem 0;
9
+ }
10
+ @media (min-width: 1024px) {
11
+ .container {
12
+ flex-direction: row;
13
+ align-items: center;
14
+ gap: 4rem;
15
+ }
16
+ .reverse {
17
+ flex-direction: row-reverse;
18
+ }
19
+ }
20
+ .textContent {
21
+ flex: 1;
22
+ opacity: 0;
23
+ transform: translateY(30px);
24
+ transition: opacity 0.8s ease-out, transform 0.8s ease-out;
25
+ color: var(--foreground);
26
+ }
27
+ .textContent.visible {
28
+ opacity: 1;
29
+ transform: translateY(0);
30
+ }
31
+ .textLeft {
32
+ text-align: left;
33
+ }
34
+ .textRight {
35
+ text-align: right;
36
+ }
37
+ .textCenter {
38
+ text-align: center;
39
+ }
40
+ .textContent p,
41
+ .textContent div,
42
+ .textContent span,
43
+ .textContent em,
44
+ .textContent strong,
45
+ .textContent a {
46
+ text-align: inherit;
47
+ max-width: none;
48
+ margin-left: unset;
49
+ margin-right: unset;
50
+ }
51
+ .gallery {
52
+ flex: 1.5;
53
+ width: 100%;
54
+ }
55
+ .artisticGrid {
56
+ display: grid;
57
+ grid-template-columns: repeat(3, 1fr);
58
+ grid-template-rows: 380px 220px;
59
+ gap: 1rem;
60
+ }
61
+ .imageWrapper {
62
+ position: relative;
63
+ overflow: hidden;
64
+ box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
65
+ border-radius: 20px;
66
+ opacity: 0;
67
+ transform: translateY(50px) scale(0.95);
68
+ transition:
69
+ opacity 0.6s ease-out,
70
+ transform 0.6s ease-out,
71
+ box-shadow 0.3s ease;
72
+ }
73
+ .imageWrapper.visible {
74
+ opacity: 1;
75
+ transform: translateY(0) scale(1);
76
+ }
77
+ .imageWrapper:hover {
78
+ transform: translateY(-5px);
79
+ box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
80
+ }
81
+ .previewImage {
82
+ object-fit: cover;
83
+ }
84
+ .artisticGrid .artistic1 .previewImage {
85
+ object-position: center top;
86
+ transform: translateY(0);
87
+ }
88
+ .artistic1 {
89
+ grid-column: 1 / 4;
90
+ grid-row: 1 / 2;
91
+ transition-delay: 0.2s;
92
+ }
93
+ .artistic2 {
94
+ grid-column: 1 / 2;
95
+ grid-row: 2 / 3;
96
+ transition-delay: 0.3s;
97
+ }
98
+ .artistic3 {
99
+ grid-column: 2 / 4;
100
+ grid-row: 2 / 3;
101
+ transition-delay: 0.4s;
102
+ }
103
+ @media (max-width: 768px) {
104
+ .artisticGrid {
105
+ grid-template-columns: 1fr;
106
+ grid-template-rows: 240px 180px 180px;
107
+ }
108
+ .artistic1,
109
+ .artistic2,
110
+ .artistic3 {
111
+ grid-column: 1 / 2;
112
+ }
113
+ .artistic1 {
114
+ grid-row: 1 / 2;
115
+ }
116
+ .artistic2 {
117
+ grid-row: 2 / 3;
118
+ }
119
+ .artistic3 {
120
+ grid-row: 3 / 4;
121
+ }
122
+ }
123
+ @media (max-width: 480px) {
124
+ .artisticGrid {
125
+ grid-template-rows: 200px 140px 140px;
126
+ }
127
+ }
128
+
129
+ /* src/components/gallery/xstaticgallery/XStaticGallery.module.css */
130
+ .galleryContainer {
131
+ width: 100%;
132
+ max-width: 80rem;
133
+ margin: 0 auto;
134
+ padding: 1rem 1rem 3rem;
135
+ }
136
+ .galleryTitle {
137
+ font-size: 1.875rem;
138
+ text-align: right;
139
+ color: var(--primary);
140
+ margin-bottom: 3rem;
141
+ opacity: 0.8;
142
+ }
143
+ .masonryGrid {
144
+ gap: 1rem;
145
+ }
146
+ .masonryItem {
147
+ break-inside: avoid;
148
+ position: relative;
149
+ border-radius: 1rem;
150
+ overflow: hidden;
151
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
152
+ margin-bottom: 1rem;
153
+ opacity: 0;
154
+ transform: translateY(20px);
155
+ transition:
156
+ opacity 0.5s ease-out,
157
+ transform 0.5s ease-out,
158
+ box-shadow 0.3s ease;
159
+ }
160
+ .masonryItem.visible {
161
+ opacity: 1;
162
+ transform: translateY(0);
163
+ }
164
+ .masonryItem:hover {
165
+ box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);
166
+ }
167
+ .imageContainer {
168
+ position: relative;
169
+ width: 100%;
170
+ overflow: hidden;
171
+ border-radius: 1rem;
172
+ }
173
+ .galleryImage {
174
+ width: 100%;
175
+ height: auto;
176
+ object-fit: cover;
177
+ display: block;
178
+ transition: transform 0.5s ease-out;
179
+ }
180
+ .masonryItem:hover .galleryImage {
181
+ transform: scale(1.05);
182
+ }
183
+ .imageOverlay {
184
+ position: absolute;
185
+ inset: 0;
186
+ background: rgba(0, 0, 0, 0);
187
+ transition: background 0.3s ease;
188
+ pointer-events: none;
189
+ }
190
+ .masonryItem:hover .imageOverlay {
191
+ background: rgba(0, 0, 0, 0.1);
192
+ }
193
+ .cols1 {
194
+ columns: 1;
195
+ }
196
+ .cols2 {
197
+ columns: 2;
198
+ }
199
+ .cols3 {
200
+ columns: 3;
201
+ }
202
+ .cols4 {
203
+ columns: 4;
204
+ }
205
+ .cols5 {
206
+ columns: 5;
207
+ }
208
+ @media (max-width: 1280px) {
209
+ .cols4,
210
+ .cols5 {
211
+ columns: 3;
212
+ }
213
+ }
214
+ @media (max-width: 768px) {
215
+ .cols3,
216
+ .cols4,
217
+ .cols5 {
218
+ columns: 2;
219
+ }
220
+ }
221
+ @media (max-width: 640px) {
222
+ .cols2,
223
+ .cols3,
224
+ .cols4,
225
+ .cols5 {
226
+ columns: 1;
227
+ }
228
+ }
229
+ /*# sourceMappingURL=index.css.map */
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/components/gallery/xmicrogallerytext/XMicroGalleryText.module.css","../../../src/components/gallery/xstaticgallery/XStaticGallery.module.css"],"sourcesContent":[".container {\n display: flex;\n flex-direction: column;\n gap: 2rem;\n width: 100%;\n align-items: center;\n margin: 2rem 0;\n}\n\n@media (min-width: 1024px) {\n .container {\n flex-direction: row;\n align-items: center;\n gap: 4rem;\n }\n \n .reverse {\n flex-direction: row-reverse;\n }\n}\n\n.textContent {\n flex: 1;\n opacity: 0;\n transform: translateY(30px);\n transition: opacity 0.8s ease-out, transform 0.8s ease-out;\n color: var(--foreground);\n}\n\n.textContent.visible {\n opacity: 1;\n transform: translateY(0);\n}\n\n.textLeft {\n text-align: left;\n}\n\n.textRight {\n text-align: right;\n}\n\n.textCenter {\n text-align: center;\n}\n\n.textContent p,\n.textContent div,\n.textContent span,\n.textContent em,\n.textContent strong,\n.textContent a {\n text-align: inherit;\n max-width: none;\n margin-left: unset;\n margin-right: unset;\n}\n\n.gallery {\n flex: 1.5;\n width: 100%;\n}\n\n.artisticGrid {\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n grid-template-rows: 380px 220px;\n gap: 1rem;\n}\n\n.imageWrapper {\n position: relative;\n overflow: hidden;\n box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);\n border-radius: 20px;\n opacity: 0;\n transform: translateY(50px) scale(0.95);\n transition: opacity 0.6s ease-out, transform 0.6s ease-out, box-shadow 0.3s ease;\n}\n\n.imageWrapper.visible {\n opacity: 1;\n transform: translateY(0) scale(1);\n}\n\n.imageWrapper:hover {\n transform: translateY(-5px);\n box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);\n}\n\n.previewImage {\n object-fit: cover;\n}\n\n.artisticGrid .artistic1 .previewImage {\n object-position: center top;\n transform: translateY(0);\n}\n\n.artistic1 {\n grid-column: 1 / 4;\n grid-row: 1 / 2;\n transition-delay: 0.2s;\n}\n\n.artistic2 {\n grid-column: 1 / 2;\n grid-row: 2 / 3;\n transition-delay: 0.3s;\n}\n\n.artistic3 {\n grid-column: 2 / 4;\n grid-row: 2 / 3;\n transition-delay: 0.4s;\n}\n\n/* Responsive Design */\n@media (max-width: 768px) {\n .artisticGrid {\n grid-template-columns: 1fr;\n grid-template-rows: 240px 180px 180px;\n }\n \n .artistic1,\n .artistic2,\n .artistic3 {\n grid-column: 1 / 2;\n }\n \n .artistic1 {\n grid-row: 1 / 2;\n }\n \n .artistic2 {\n grid-row: 2 / 3;\n }\n \n .artistic3 {\n grid-row: 3 / 4;\n }\n}\n\n@media (max-width: 480px) {\n .artisticGrid {\n grid-template-rows: 200px 140px 140px;\n }\n}\n",".galleryContainer {\n width: 100%;\n max-width: 80rem;\n margin: 0 auto;\n padding: 1rem 1rem 3rem;\n}\n\n.galleryTitle {\n font-size: 1.875rem;\n text-align: right;\n color: var(--primary);\n margin-bottom: 3rem;\n opacity: 0.8;\n}\n\n/* Masonry via CSS columns */\n.masonryGrid {\n gap: 1rem;\n}\n\n.masonryItem {\n break-inside: avoid;\n position: relative;\n border-radius: 1rem;\n overflow: hidden;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);\n margin-bottom: 1rem;\n opacity: 0;\n transform: translateY(20px);\n transition: opacity 0.5s ease-out, transform 0.5s ease-out, box-shadow 0.3s ease;\n}\n\n.masonryItem.visible {\n opacity: 1;\n transform: translateY(0);\n}\n\n.masonryItem:hover {\n box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);\n}\n\n.imageContainer {\n position: relative;\n width: 100%;\n overflow: hidden;\n border-radius: 1rem;\n}\n\n.galleryImage {\n width: 100%;\n height: auto;\n object-fit: cover;\n display: block;\n transition: transform 0.5s ease-out;\n}\n\n.masonryItem:hover .galleryImage {\n transform: scale(1.05);\n}\n\n.imageOverlay {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0);\n transition: background 0.3s ease;\n pointer-events: none;\n}\n\n.masonryItem:hover .imageOverlay {\n background: rgba(0, 0, 0, 0.1);\n}\n\n/* Column count via CSS custom property */\n.cols1 { columns: 1; }\n.cols2 { columns: 2; }\n.cols3 { columns: 3; }\n.cols4 { columns: 4; }\n.cols5 { columns: 5; }\n\n/* Responsive overrides */\n@media (max-width: 1280px) {\n .cols4, .cols5 { columns: 3; }\n}\n\n@media (max-width: 768px) {\n .cols3, .cols4, .cols5 { columns: 2; }\n}\n\n@media (max-width: 640px) {\n .cols2, .cols3, .cols4, .cols5 { columns: 1; }\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ import * as react_jsx_runtime from 'react/jsx-runtime';
3
+
4
+ interface XMicroGalleryImage {
5
+ src: string;
6
+ alt: string;
7
+ }
8
+ interface XMicroGalleryTextProps {
9
+ images: XMicroGalleryImage[];
10
+ text: React.ReactNode;
11
+ textPosition?: 'left' | 'right';
12
+ textAlign?: 'left' | 'right' | 'center';
13
+ autoShuffle?: boolean;
14
+ shuffleInterval?: number;
15
+ }
16
+ declare const XMicroGalleryText: React.FC<XMicroGalleryTextProps>;
17
+
18
+ interface XStaticGalleryImage {
19
+ src: string;
20
+ alt: string;
21
+ }
22
+ interface XStaticGalleryProps {
23
+ images: XStaticGalleryImage[];
24
+ columns?: 1 | 2 | 3 | 4 | 5;
25
+ title?: string;
26
+ }
27
+ declare function XStaticGallery({ images, columns, title }: XStaticGalleryProps): react_jsx_runtime.JSX.Element;
28
+
29
+ export { type XMicroGalleryImage, XMicroGalleryText, type XMicroGalleryTextProps, XStaticGallery, type XStaticGalleryImage, type XStaticGalleryProps };
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ import * as react_jsx_runtime from 'react/jsx-runtime';
3
+
4
+ interface XMicroGalleryImage {
5
+ src: string;
6
+ alt: string;
7
+ }
8
+ interface XMicroGalleryTextProps {
9
+ images: XMicroGalleryImage[];
10
+ text: React.ReactNode;
11
+ textPosition?: 'left' | 'right';
12
+ textAlign?: 'left' | 'right' | 'center';
13
+ autoShuffle?: boolean;
14
+ shuffleInterval?: number;
15
+ }
16
+ declare const XMicroGalleryText: React.FC<XMicroGalleryTextProps>;
17
+
18
+ interface XStaticGalleryImage {
19
+ src: string;
20
+ alt: string;
21
+ }
22
+ interface XStaticGalleryProps {
23
+ images: XStaticGalleryImage[];
24
+ columns?: 1 | 2 | 3 | 4 | 5;
25
+ title?: string;
26
+ }
27
+ declare function XStaticGallery({ images, columns, title }: XStaticGalleryProps): react_jsx_runtime.JSX.Element;
28
+
29
+ export { type XMicroGalleryImage, XMicroGalleryText, type XMicroGalleryTextProps, XStaticGallery, type XStaticGalleryImage, type XStaticGalleryProps };
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/components/gallery/index.ts
31
+ var gallery_exports = {};
32
+ __export(gallery_exports, {
33
+ XMicroGalleryText: () => XMicroGalleryText_default2,
34
+ XStaticGallery: () => XStaticGallery
35
+ });
36
+ module.exports = __toCommonJS(gallery_exports);
37
+
38
+ // src/components/gallery/xmicrogallerytext/XMicroGalleryText.tsx
39
+ var import_react = __toESM(require("react"));
40
+ var import_image = __toESM(require("next/image"));
41
+ var import_framer_motion = require("framer-motion");
42
+
43
+ // src/components/gallery/xmicrogallerytext/XMicroGalleryText.module.css
44
+ var XMicroGalleryText_default = {};
45
+
46
+ // src/components/gallery/xmicrogallerytext/XMicroGalleryText.tsx
47
+ var import_jsx_runtime = require("react/jsx-runtime");
48
+ var DISPLAY_COUNT = 3;
49
+ var XMicroGalleryText = ({
50
+ images,
51
+ text,
52
+ textPosition = "left",
53
+ textAlign = "left",
54
+ autoShuffle = false,
55
+ shuffleInterval = 5e3
56
+ }) => {
57
+ const containerRef = (0, import_react.useRef)(null);
58
+ const [startIndex, setStartIndex] = import_react.default.useState(0);
59
+ const visibleImages = import_react.default.useMemo(() => {
60
+ const result = [];
61
+ for (let i = 0; i < DISPLAY_COUNT; i++) {
62
+ result.push(images[(startIndex + i) % images.length]);
63
+ }
64
+ return result;
65
+ }, [images, startIndex]);
66
+ import_react.default.useEffect(() => {
67
+ if (!autoShuffle || images.length <= DISPLAY_COUNT) return;
68
+ const intervalId = setInterval(() => {
69
+ setStartIndex((prev) => (prev + 1) % images.length);
70
+ }, shuffleInterval);
71
+ return () => clearInterval(intervalId);
72
+ }, [autoShuffle, shuffleInterval, images.length]);
73
+ const [isVisible, setIsVisible] = import_react.default.useState(false);
74
+ (0, import_react.useEffect)(() => {
75
+ const observer = new IntersectionObserver(
76
+ ([entry]) => {
77
+ if (entry.isIntersecting) {
78
+ setIsVisible(true);
79
+ observer.disconnect();
80
+ }
81
+ },
82
+ {
83
+ threshold: 0.1,
84
+ rootMargin: "0px 0px -50px 0px"
85
+ }
86
+ );
87
+ if (containerRef.current) {
88
+ observer.observe(containerRef.current);
89
+ }
90
+ return () => observer.disconnect();
91
+ }, []);
92
+ const isTextRight = textPosition === "right";
93
+ const alignClass = {
94
+ left: XMicroGalleryText_default.textLeft,
95
+ right: XMicroGalleryText_default.textRight,
96
+ center: XMicroGalleryText_default.textCenter
97
+ }[textAlign];
98
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { ref: containerRef, className: `${XMicroGalleryText_default.container} ${isTextRight ? XMicroGalleryText_default.reverse : ""}`, children: [
99
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: `${XMicroGalleryText_default.textContent} ${alignClass} ${isVisible ? XMicroGalleryText_default.visible : ""}`, children: typeof text === "string" ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { dangerouslySetInnerHTML: { __html: text } }) : text }),
100
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: XMicroGalleryText_default.gallery, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: XMicroGalleryText_default.artisticGrid, children: visibleImages.map((image, index) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
101
+ import_framer_motion.motion.div,
102
+ {
103
+ layout: true,
104
+ className: `${XMicroGalleryText_default.imageWrapper} ${XMicroGalleryText_default[`artistic${index + 1}`]} ${isVisible ? XMicroGalleryText_default.visible : ""}`,
105
+ style: { transitionProperty: "opacity, box-shadow" },
106
+ transition: {
107
+ layout: { type: "spring", stiffness: 80, damping: 20 }
108
+ },
109
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
110
+ import_image.default,
111
+ {
112
+ src: image.src,
113
+ alt: image.alt,
114
+ fill: true,
115
+ className: XMicroGalleryText_default.previewImage,
116
+ sizes: "(max-width: 768px) 100vw, (max-width: 1024px) 50vw, 33vw"
117
+ }
118
+ )
119
+ },
120
+ image.src
121
+ )) }) })
122
+ ] });
123
+ };
124
+ var XMicroGalleryText_default2 = XMicroGalleryText;
125
+
126
+ // src/components/gallery/xstaticgallery/XStaticGallery.tsx
127
+ var import_react2 = require("react");
128
+ var import_image2 = __toESM(require("next/image"));
129
+
130
+ // src/components/gallery/xstaticgallery/XStaticGallery.module.css
131
+ var XStaticGallery_default = {};
132
+
133
+ // src/components/gallery/xstaticgallery/XStaticGallery.tsx
134
+ var import_jsx_runtime2 = require("react/jsx-runtime");
135
+ var COLUMN_CLASSES = {
136
+ 1: XStaticGallery_default.cols1,
137
+ 2: XStaticGallery_default.cols2,
138
+ 3: XStaticGallery_default.cols3,
139
+ 4: XStaticGallery_default.cols4,
140
+ 5: XStaticGallery_default.cols5
141
+ };
142
+ function XStaticGallery({ images, columns = 4, title }) {
143
+ const containerRef = (0, import_react2.useRef)(null);
144
+ (0, import_react2.useEffect)(() => {
145
+ const observer = new IntersectionObserver(
146
+ (entries) => {
147
+ entries.forEach((entry) => {
148
+ if (entry.isIntersecting) {
149
+ entry.target.classList.add(XStaticGallery_default.visible);
150
+ }
151
+ });
152
+ },
153
+ {
154
+ threshold: 0.1,
155
+ rootMargin: "0px 0px -50px 0px"
156
+ }
157
+ );
158
+ const items = containerRef.current?.querySelectorAll(`.${XStaticGallery_default.masonryItem}`);
159
+ items?.forEach((el) => observer.observe(el));
160
+ return () => observer.disconnect();
161
+ }, []);
162
+ const colClass = COLUMN_CLASSES[columns] || COLUMN_CLASSES[4];
163
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { ref: containerRef, className: XStaticGallery_default.galleryContainer, children: [
164
+ title && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("h2", { className: XStaticGallery_default.galleryTitle, children: title }),
165
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: `${XStaticGallery_default.masonryGrid} ${colClass}`, children: images.map((image, index) => /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: XStaticGallery_default.masonryItem, children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: XStaticGallery_default.imageContainer, children: [
166
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
167
+ import_image2.default,
168
+ {
169
+ src: image.src,
170
+ alt: image.alt,
171
+ width: 600,
172
+ height: 600,
173
+ className: XStaticGallery_default.galleryImage,
174
+ loading: "lazy",
175
+ sizes: "(max-width: 640px) 100vw, (max-width: 768px) 50vw, (max-width: 1280px) 33vw, 25vw"
176
+ }
177
+ ),
178
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: XStaticGallery_default.imageOverlay })
179
+ ] }) }, index)) })
180
+ ] });
181
+ }
182
+ // Annotate the CommonJS export names for ESM import in node:
183
+ 0 && (module.exports = {
184
+ XMicroGalleryText,
185
+ XStaticGallery
186
+ });
187
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/components/gallery/index.ts","../../../src/components/gallery/xmicrogallerytext/XMicroGalleryText.tsx","../../../src/components/gallery/xmicrogallerytext/XMicroGalleryText.module.css","../../../src/components/gallery/xstaticgallery/XStaticGallery.tsx","../../../src/components/gallery/xstaticgallery/XStaticGallery.module.css"],"sourcesContent":["export { XMicroGalleryText } from \"./xmicrogallerytext\";\nexport { XStaticGallery } from \"./xstaticgallery\";\nexport type { XMicroGalleryTextProps, XMicroGalleryImage } from \"./xmicrogallerytext\";\nexport type { XStaticGalleryProps, XStaticGalleryImage } from \"./xstaticgallery\";\n","import React, { useEffect, useRef } from 'react';\nimport Image from 'next/image';\nimport { motion } from 'framer-motion';\nimport styles from './XMicroGalleryText.module.css';\n\nexport interface XMicroGalleryImage {\n src: string;\n alt: string;\n}\n\nexport interface XMicroGalleryTextProps {\n images: XMicroGalleryImage[];\n text: React.ReactNode;\n textPosition?: 'left' | 'right';\n textAlign?: 'left' | 'right' | 'center';\n autoShuffle?: boolean;\n shuffleInterval?: number;\n}\n\nconst DISPLAY_COUNT = 3;\n\nconst XMicroGalleryText: React.FC<XMicroGalleryTextProps> = ({ \n images, \n text, \n textPosition = 'left',\n textAlign = 'left',\n autoShuffle = false,\n shuffleInterval = 5000\n}) => {\n const containerRef = useRef<HTMLDivElement>(null);\n const [startIndex, setStartIndex] = React.useState(0);\n\n const visibleImages = React.useMemo(() => {\n const result: XMicroGalleryImage[] = [];\n for (let i = 0; i < DISPLAY_COUNT; i++) {\n result.push(images[(startIndex + i) % images.length]);\n }\n return result;\n }, [images, startIndex]);\n\n React.useEffect(() => {\n if (!autoShuffle || images.length <= DISPLAY_COUNT) return;\n\n const intervalId = setInterval(() => {\n setStartIndex((prev) => (prev + 1) % images.length);\n }, shuffleInterval);\n\n return () => clearInterval(intervalId);\n }, [autoShuffle, shuffleInterval, images.length]);\n\n const [isVisible, setIsVisible] = React.useState(false);\n\n useEffect(() => {\n const observer = new IntersectionObserver(\n ([entry]) => {\n if (entry.isIntersecting) {\n setIsVisible(true);\n observer.disconnect();\n }\n },\n {\n threshold: 0.1,\n rootMargin: '0px 0px -50px 0px'\n }\n );\n\n if (containerRef.current) {\n observer.observe(containerRef.current);\n }\n\n return () => observer.disconnect();\n }, []);\n\n const isTextRight = textPosition === 'right';\n\n const alignClass = {\n left: styles.textLeft,\n right: styles.textRight,\n center: styles.textCenter,\n }[textAlign];\n\n return (\n <div ref={containerRef} className={`${styles.container} ${isTextRight ? styles.reverse : ''}`}>\n <div className={`${styles.textContent} ${alignClass} ${isVisible ? styles.visible : ''}`}>\n {typeof text === 'string' ? (\n <div dangerouslySetInnerHTML={{ __html: text }} />\n ) : (\n text\n )}\n </div>\n \n <div className={styles.gallery}>\n <div className={styles.artisticGrid}>\n {visibleImages.map((image, index) => (\n <motion.div \n layout\n key={image.src} \n className={`${styles.imageWrapper} ${styles[`artistic${index + 1}`]} ${isVisible ? styles.visible : ''}`}\n style={{ transitionProperty: 'opacity, box-shadow' }}\n transition={{\n layout: { type: \"spring\", stiffness: 80, damping: 20 }\n }}\n >\n <Image\n src={image.src}\n alt={image.alt}\n fill\n className={styles.previewImage}\n sizes=\"(max-width: 768px) 100vw, (max-width: 1024px) 50vw, 33vw\"\n />\n </motion.div>\n ))}\n </div>\n </div>\n </div>\n );\n};\n\nexport default XMicroGalleryText;\n",".container {\n display: flex;\n flex-direction: column;\n gap: 2rem;\n width: 100%;\n align-items: center;\n margin: 2rem 0;\n}\n\n@media (min-width: 1024px) {\n .container {\n flex-direction: row;\n align-items: center;\n gap: 4rem;\n }\n \n .reverse {\n flex-direction: row-reverse;\n }\n}\n\n.textContent {\n flex: 1;\n opacity: 0;\n transform: translateY(30px);\n transition: opacity 0.8s ease-out, transform 0.8s ease-out;\n color: var(--foreground);\n}\n\n.textContent.visible {\n opacity: 1;\n transform: translateY(0);\n}\n\n.textLeft {\n text-align: left;\n}\n\n.textRight {\n text-align: right;\n}\n\n.textCenter {\n text-align: center;\n}\n\n.textContent p,\n.textContent div,\n.textContent span,\n.textContent em,\n.textContent strong,\n.textContent a {\n text-align: inherit;\n max-width: none;\n margin-left: unset;\n margin-right: unset;\n}\n\n.gallery {\n flex: 1.5;\n width: 100%;\n}\n\n.artisticGrid {\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n grid-template-rows: 380px 220px;\n gap: 1rem;\n}\n\n.imageWrapper {\n position: relative;\n overflow: hidden;\n box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);\n border-radius: 20px;\n opacity: 0;\n transform: translateY(50px) scale(0.95);\n transition: opacity 0.6s ease-out, transform 0.6s ease-out, box-shadow 0.3s ease;\n}\n\n.imageWrapper.visible {\n opacity: 1;\n transform: translateY(0) scale(1);\n}\n\n.imageWrapper:hover {\n transform: translateY(-5px);\n box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);\n}\n\n.previewImage {\n object-fit: cover;\n}\n\n.artisticGrid .artistic1 .previewImage {\n object-position: center top;\n transform: translateY(0);\n}\n\n.artistic1 {\n grid-column: 1 / 4;\n grid-row: 1 / 2;\n transition-delay: 0.2s;\n}\n\n.artistic2 {\n grid-column: 1 / 2;\n grid-row: 2 / 3;\n transition-delay: 0.3s;\n}\n\n.artistic3 {\n grid-column: 2 / 4;\n grid-row: 2 / 3;\n transition-delay: 0.4s;\n}\n\n/* Responsive Design */\n@media (max-width: 768px) {\n .artisticGrid {\n grid-template-columns: 1fr;\n grid-template-rows: 240px 180px 180px;\n }\n \n .artistic1,\n .artistic2,\n .artistic3 {\n grid-column: 1 / 2;\n }\n \n .artistic1 {\n grid-row: 1 / 2;\n }\n \n .artistic2 {\n grid-row: 2 / 3;\n }\n \n .artistic3 {\n grid-row: 3 / 4;\n }\n}\n\n@media (max-width: 480px) {\n .artisticGrid {\n grid-template-rows: 200px 140px 140px;\n }\n}\n","\"use client\";\nimport React, { useEffect, useRef } from 'react';\nimport Image from 'next/image';\nimport styles from './XStaticGallery.module.css';\n\nexport interface XStaticGalleryImage {\n src: string;\n alt: string;\n}\n\nexport interface XStaticGalleryProps {\n images: XStaticGalleryImage[];\n columns?: 1 | 2 | 3 | 4 | 5;\n title?: string;\n}\n\nconst COLUMN_CLASSES: Record<number, string> = {\n 1: styles.cols1,\n 2: styles.cols2,\n 3: styles.cols3,\n 4: styles.cols4,\n 5: styles.cols5,\n};\n\nexport default function XStaticGallery({ images, columns = 4, title }: XStaticGalleryProps) {\n const containerRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const observer = new IntersectionObserver(\n (entries) => {\n entries.forEach((entry) => {\n if (entry.isIntersecting) {\n entry.target.classList.add(styles.visible);\n }\n });\n },\n {\n threshold: 0.1,\n rootMargin: '0px 0px -50px 0px',\n }\n );\n\n const items = containerRef.current?.querySelectorAll(`.${styles.masonryItem}`);\n items?.forEach((el) => observer.observe(el));\n\n return () => observer.disconnect();\n }, []);\n\n const colClass = COLUMN_CLASSES[columns] || COLUMN_CLASSES[4];\n\n return (\n <div ref={containerRef} className={styles.galleryContainer}>\n {title && <h2 className={styles.galleryTitle}>{title}</h2>}\n\n <div className={`${styles.masonryGrid} ${colClass}`}>\n {images.map((image, index) => (\n <div key={index} className={styles.masonryItem}>\n <div className={styles.imageContainer}>\n <Image\n src={image.src}\n alt={image.alt}\n width={600}\n height={600}\n className={styles.galleryImage}\n loading=\"lazy\"\n sizes=\"(max-width: 640px) 100vw, (max-width: 768px) 50vw, (max-width: 1280px) 33vw, 25vw\"\n />\n <div className={styles.imageOverlay} />\n </div>\n </div>\n ))}\n </div>\n </div>\n );\n}\n",".galleryContainer {\n width: 100%;\n max-width: 80rem;\n margin: 0 auto;\n padding: 1rem 1rem 3rem;\n}\n\n.galleryTitle {\n font-size: 1.875rem;\n text-align: right;\n color: var(--primary);\n margin-bottom: 3rem;\n opacity: 0.8;\n}\n\n/* Masonry via CSS columns */\n.masonryGrid {\n gap: 1rem;\n}\n\n.masonryItem {\n break-inside: avoid;\n position: relative;\n border-radius: 1rem;\n overflow: hidden;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);\n margin-bottom: 1rem;\n opacity: 0;\n transform: translateY(20px);\n transition: opacity 0.5s ease-out, transform 0.5s ease-out, box-shadow 0.3s ease;\n}\n\n.masonryItem.visible {\n opacity: 1;\n transform: translateY(0);\n}\n\n.masonryItem:hover {\n box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);\n}\n\n.imageContainer {\n position: relative;\n width: 100%;\n overflow: hidden;\n border-radius: 1rem;\n}\n\n.galleryImage {\n width: 100%;\n height: auto;\n object-fit: cover;\n display: block;\n transition: transform 0.5s ease-out;\n}\n\n.masonryItem:hover .galleryImage {\n transform: scale(1.05);\n}\n\n.imageOverlay {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0);\n transition: background 0.3s ease;\n pointer-events: none;\n}\n\n.masonryItem:hover .imageOverlay {\n background: rgba(0, 0, 0, 0.1);\n}\n\n/* Column count via CSS custom property */\n.cols1 { columns: 1; }\n.cols2 { columns: 2; }\n.cols3 { columns: 3; }\n.cols4 { columns: 4; }\n.cols5 { columns: 5; }\n\n/* Responsive overrides */\n@media (max-width: 1280px) {\n .cols4, .cols5 { columns: 3; }\n}\n\n@media (max-width: 768px) {\n .cols3, .cols4, .cols5 { columns: 2; }\n}\n\n@media (max-width: 640px) {\n .cols2, .cols3, .cols4, .cols5 { columns: 1; }\n}\n"],"mappings":"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","names":["XMicroGalleryText_default","React","Image","XMicroGalleryText_default","import_react","import_image","import_jsx_runtime","Image"]}
@@ -0,0 +1,9 @@
1
+ import {
2
+ XMicroGalleryText_default,
3
+ XStaticGallery
4
+ } from "../../chunk-2OAXRRVQ.mjs";
5
+ export {
6
+ XMicroGalleryText_default as XMicroGalleryText,
7
+ XStaticGallery
8
+ };
9
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}