@morphika/andami 0.5.1 → 0.5.2
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/app/admin/assets/page.tsx +6 -6
- package/app/admin/database/page.tsx +302 -302
- package/app/admin/error.tsx +53 -53
- package/app/admin/layout.tsx +320 -320
- package/app/admin/navigation/page.tsx +255 -255
- package/app/admin/pages/[slug]/page.tsx +6 -6
- package/app/admin/pages/page.tsx +11 -11
- package/app/admin/projects/page.tsx +14 -14
- package/app/admin/setup/page.tsx +1 -1
- package/app/admin/styles/page.tsx +1 -1
- package/components/admin/MetadataEditor.tsx +6 -6
- package/components/admin/nav-builder/NavBuilder.tsx +1 -1
- package/components/admin/nav-builder/NavBuilderGrid.tsx +3 -3
- package/components/admin/nav-builder/NavGridCell.tsx +48 -48
- package/components/admin/nav-builder/NavGridItem.tsx +4 -4
- package/components/admin/nav-builder/NavItemSettings.tsx +331 -331
- package/components/admin/nav-builder/NavItemTypePicker.tsx +102 -102
- package/components/admin/nav-builder/NavLivePreview.tsx +1 -1
- package/components/admin/nav-builder/NavMobileLivePreview.tsx +226 -226
- package/components/admin/nav-builder/NavMobileSettings.tsx +242 -242
- package/components/admin/nav-builder/NavSettingsFields.tsx +514 -514
- package/components/admin/setup-wizard/BrandingStep.tsx +3 -3
- package/components/admin/setup-wizard/DatabaseStep.tsx +2 -2
- package/components/admin/setup-wizard/DoneStep.tsx +1 -1
- package/components/admin/setup-wizard/SetupWizard.tsx +4 -4
- package/components/admin/setup-wizard/StorageStep.tsx +2 -2
- package/components/admin/setup-wizard/WelcomeStep.tsx +2 -2
- package/components/admin/styles/ColorsEditor.tsx +2 -2
- package/components/admin/styles/FontsEditor.tsx +6 -6
- package/components/admin/styles/GridLayoutEditor.tsx +9 -9
- package/components/admin/styles/LinksButtonsEditor.tsx +5 -5
- package/components/admin/styles/TypographyEditor.tsx +6 -6
- package/components/admin/styles/shared.tsx +68 -68
- package/components/blocks/AudioBlockRenderer.tsx +286 -286
- package/components/blocks/MarqueeBlockRenderer.tsx +316 -0
- package/components/blocks/ProjectCarouselBlockRenderer.tsx +1 -1
- package/components/builder/BlockCardIcons.tsx +316 -316
- package/components/builder/BlockTypePicker.tsx +1 -1
- package/components/builder/BubbleIcons.tsx +90 -0
- package/components/builder/BuilderCanvas.tsx +2 -0
- package/components/builder/CanvasMinimap.tsx +2 -2
- package/components/builder/CoverSectionCanvas.tsx +363 -363
- package/components/builder/DeviceFrame.tsx +1 -1
- package/components/builder/DndWrapper.tsx +3 -3
- package/components/builder/InsertionLines.tsx +1 -1
- package/components/builder/SectionCardIcons.tsx +421 -320
- package/components/builder/SectionEditorBar.tsx +1 -1
- package/components/builder/SectionTypePicker.tsx +4 -4
- package/components/builder/SectionV2Canvas.tsx +1 -1
- package/components/builder/SectionV2Column.tsx +69 -67
- package/components/builder/SortableBlock.tsx +93 -73
- package/components/builder/SortableRow.tsx +27 -26
- package/components/builder/VirtualAssetGrid.tsx +2 -2
- package/components/builder/asset-browser/R2BrowserContent.tsx +11 -11
- package/components/builder/blockStyles.tsx +192 -185
- package/components/builder/color-picker/AlphaSlider.tsx +141 -141
- package/components/builder/color-picker/ColorInputs.tsx +105 -105
- package/components/builder/color-picker/EyedropperButton.tsx +74 -74
- package/components/builder/color-picker/HueSlider.tsx +124 -124
- package/components/builder/color-picker/SaturationCanvas.tsx +142 -142
- package/components/builder/color-picker/SwatchBar.tsx +93 -93
- package/components/builder/editors/AudioBlockEditor.tsx +242 -242
- package/components/builder/editors/BeforeAfterBlockEditor.tsx +360 -360
- package/components/builder/editors/ButtonBlockEditor.tsx +4 -4
- package/components/builder/editors/EnterAnimationPicker.tsx +2 -2
- package/components/builder/editors/HoverEffectPicker.tsx +2 -2
- package/components/builder/editors/ImageBlockEditor.tsx +2 -2
- package/components/builder/editors/ImageGridBlockEditor.tsx +4 -4
- package/components/builder/editors/MarqueeBlockEditor.tsx +621 -0
- package/components/builder/editors/ProjectCarouselBlockEditor.tsx +443 -443
- package/components/builder/editors/ProjectGridEditor.tsx +9 -9
- package/components/builder/editors/SpacerBlockEditor.tsx +5 -5
- package/components/builder/editors/StaggerSettings.tsx +109 -109
- package/components/builder/editors/TextBlockEditor.tsx +3 -3
- package/components/builder/editors/TextStylePicker.tsx +1 -1
- package/components/builder/editors/VideoBlockEditor.tsx +2 -2
- package/components/builder/editors/index.ts +11 -10
- package/components/builder/editors/shared.tsx +6 -6
- package/components/builder/live-preview/LiveAudioPreview.tsx +120 -120
- package/components/builder/live-preview/LiveBeforeAfterPreview.tsx +1 -1
- package/components/builder/live-preview/LiveImageGridPreview.tsx +10 -2
- package/components/builder/live-preview/LiveImagePreview.tsx +1 -1
- package/components/builder/live-preview/LiveMarqueePreview.tsx +39 -0
- package/components/builder/live-preview/LiveProjectCarouselPreview.tsx +1 -1
- package/components/builder/live-preview/LiveVideoPreview.tsx +1 -1
- package/components/builder/live-preview/ProjectCardWrapper.tsx +291 -291
- package/components/builder/settings-panel/AnimationTab.tsx +138 -138
- package/components/builder/settings-panel/BlockLayoutTab.tsx +7 -7
- package/components/builder/settings-panel/CardEntranceSection.tsx +114 -114
- package/components/builder/settings-panel/ColumnV2Settings.tsx +5 -5
- package/components/builder/settings-panel/CoverSectionLayoutTab.tsx +71 -71
- package/components/builder/settings-panel/CoverSectionSettings.tsx +335 -335
- package/components/builder/settings-panel/PageSettings.tsx +3 -3
- package/components/builder/settings-panel/ParallaxSlideSettings.tsx +2 -2
- package/components/builder/settings-panel/SectionV2AnimationTab.tsx +4 -4
- package/components/builder/settings-panel/SectionV2LayoutTab.tsx +356 -356
- package/components/builder/settings-panel/SectionV2Settings.tsx +14 -14
- package/components/builder/settings-panel/TRBLInputs.tsx +1 -1
- package/lib/animation/enter-types.ts +1 -0
- package/lib/animation/hover-effect-presets.ts +210 -210
- package/lib/animation/hover-effect-types.ts +1 -0
- package/lib/builder/block-registrations.ts +468 -417
- package/lib/builder/constants.ts +111 -111
- package/lib/builder/store-sections.ts +2 -2
- package/lib/builder/types-slices.ts +414 -414
- package/lib/builder/types.ts +4 -1
- package/lib/config/index.ts +27 -27
- package/lib/sanity/types.ts +98 -1
- package/lib/version.ts +1 -1
- package/package.json +1 -1
- package/sanity/schemas/blocks/audioBlock.ts +69 -69
- package/sanity/schemas/blocks/index.ts +12 -11
- package/sanity/schemas/blocks/marqueeBlock.ts +292 -0
- package/sanity/schemas/index.ts +120 -117
- package/styles/admin.css +85 -85
- package/styles/animations.css +237 -237
- package/styles/base.css +114 -114
|
@@ -75,7 +75,7 @@ function BlockCard({
|
|
|
75
75
|
aria-hidden="true"
|
|
76
76
|
className="absolute inset-0 rounded-2xl pointer-events-none"
|
|
77
77
|
style={{
|
|
78
|
-
boxShadow: isHovered ? "inset 0 0 0 2px #
|
|
78
|
+
boxShadow: isHovered ? "inset 0 0 0 2px #3580f9" : "inset 0 0 0 2px transparent",
|
|
79
79
|
transition: "box-shadow 160ms ease",
|
|
80
80
|
}}
|
|
81
81
|
/>
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* BubbleIcons — shared icon set + tooltip wrapper for the block & column bubbles
|
|
5
|
+
* floating at the top-outside of each entity in the visual builder.
|
|
6
|
+
*
|
|
7
|
+
* Icons come from the Tabler set, re-exported as filled <path> SVGs so they
|
|
8
|
+
* scale cleanly without stroke-width inconsistencies. Viewbox is 24×24; the
|
|
9
|
+
* default display size is 12px (pill-scale).
|
|
10
|
+
*
|
|
11
|
+
* Tooltip styling mirrors the admin sidebar's group-hover tooltip
|
|
12
|
+
* (app/admin/layout.tsx) — dark pill, 150ms fade + slide-in.
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
import type { ReactNode } from "react";
|
|
16
|
+
|
|
17
|
+
// ============================================
|
|
18
|
+
// Icons (filled, 24×24 viewBox)
|
|
19
|
+
// ============================================
|
|
20
|
+
|
|
21
|
+
interface IconProps {
|
|
22
|
+
size?: number;
|
|
23
|
+
color?: string;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export function DragDropIcon({ size = 12, color = "currentColor" }: IconProps) {
|
|
27
|
+
return (
|
|
28
|
+
<svg width={size} height={size} viewBox="0 0 24 24" fill={color} aria-hidden="true">
|
|
29
|
+
<path d="M11,18H9c-0.6,0-1-0.4-1-1V9c0-0.6,0.4-1,1-1h8c0.6,0,1,0.4,1,1v2c0,0.6,0.4,1,1,1s1-0.4,1-1V9c0-1.7-1.3-3-3-3H9 C7.3,6,6,7.3,6,9v8c0,1.7,1.3,3,3,3h2c0.6,0,1-0.4,1-1S11.6,18,11,18z" />
|
|
30
|
+
<path d="M22.3,15.1l-9-3c-0.4-0.1-0.8,0-1,0.2c-0.3,0.3-0.4,0.7-0.2,1l3,9c0.1,0.4,0.5,0.7,0.9,0.7c0,0,0,0,0.1,0 c0.4,0,0.7-0.2,0.9-0.6l1.9-3.7l3.7-1.9c0.4-0.2,0.6-0.6,0.5-1C23,15.5,22.7,15.2,22.3,15.1z M17.6,17.1c-0.2,0.1-0.4,0.3-0.4,0.4 l-0.9,1.8l-1.6-4.8l4.8,1.6L17.6,17.1z" />
|
|
31
|
+
<path d="M3,2C2.4,2,2,2.5,2,3s0.4,1,1,1s1-0.4,1-1v0C4,2.4,3.6,2,3,2z" />
|
|
32
|
+
<path d="M7,4c0.6,0,1-0.4,1-1v0c0-0.6-0.4-1-1-1S6,2.5,6,3S6.4,4,7,4z" />
|
|
33
|
+
<path d="M11,4c0.6,0,1-0.4,1-1v0c0-0.6-0.4-1-1-1s-1,0.5-1,1S10.4,4,11,4z" />
|
|
34
|
+
<path d="M15,4c0.6,0,1-0.4,1-1v0c0-0.6-0.4-1-1-1s-1,0.5-1,1S14.4,4,15,4z" />
|
|
35
|
+
<path d="M3,6C2.4,6,2,6.5,2,7s0.4,1,1,1s1-0.4,1-1v0C4,6.4,3.6,6,3,6z" />
|
|
36
|
+
<path d="M3,10c-0.6,0-1,0.5-1,1s0.4,1,1,1s1-0.4,1-1v0C4,10.4,3.6,10,3,10z" />
|
|
37
|
+
<path d="M3,14c-0.6,0-1,0.5-1,1s0.4,1,1,1s1-0.4,1-1v0C4,14.4,3.6,14,3,14z" />
|
|
38
|
+
</svg>
|
|
39
|
+
);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export function CopyIcon({ size = 12, color = "currentColor" }: IconProps) {
|
|
43
|
+
return (
|
|
44
|
+
<svg width={size} height={size} viewBox="0 0 24 24" fill={color} aria-hidden="true">
|
|
45
|
+
<path d="M18.3,22H9.7c-2,0-3.7-1.6-3.7-3.7V9.7C6,7.6,7.6,6,9.7,6h8.7c2,0,3.7,1.6,3.7,3.7v8.7C22,20.4,20.4,22,18.3,22z M9.7,8 C8.7,8,8,8.7,8,9.7v8.7C8,19.3,8.7,20,9.7,20h8.7c0.9,0,1.7-0.7,1.7-1.7V9.7C20,8.7,19.3,8,18.3,8H9.7z" />
|
|
46
|
+
<path d="M4,17.7c-0.2,0-0.3,0-0.5-0.1C2.6,17.1,2,16.1,2,15V5c0-1.7,1.3-3,3-3h10c1.5,0,2.2,1.1,2.4,1.5C17.6,4,17.5,4.6,17,4.9 c-0.5,0.3-1.1,0.1-1.4-0.4C15.4,4,15.2,4,15,4H5C4.4,4,4,4.4,4,5v10c0,0.4,0.2,0.7,0.5,0.9c0.5,0.3,0.6,0.9,0.4,1.4 C4.7,17.6,4.4,17.7,4,17.7z" />
|
|
47
|
+
</svg>
|
|
48
|
+
);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export function ArrowDownIcon({ size = 12, color = "currentColor" }: IconProps) {
|
|
52
|
+
return (
|
|
53
|
+
<svg width={size} height={size} viewBox="0 0 24 24" fill={color} aria-hidden="true">
|
|
54
|
+
<path d="M16.7,14.3c-0.4-0.4-1-0.4-1.4,0L13,16.6V5c0-0.6-0.4-1-1-1s-1,0.4-1,1v11.6l-2.3-2.3c-0.4-0.4-1-0.4-1.4,0s-0.4,1,0,1.4 l4,4c0.1,0.1,0.2,0.2,0.3,0.2C11.7,20,11.9,20,12,20s0.3,0,0.4-0.1c0.1-0.1,0.2-0.1,0.3-0.2l4-4C17.1,15.3,17.1,14.7,16.7,14.3z" />
|
|
55
|
+
</svg>
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export function ArrowUpIcon({ size = 12, color = "currentColor" }: IconProps) {
|
|
60
|
+
return (
|
|
61
|
+
<svg width={size} height={size} viewBox="0 0 24 24" fill={color} aria-hidden="true" style={{ transform: "rotate(180deg)" }}>
|
|
62
|
+
<path d="M16.7,14.3c-0.4-0.4-1-0.4-1.4,0L13,16.6V5c0-0.6-0.4-1-1-1s-1,0.4-1,1v11.6l-2.3-2.3c-0.4-0.4-1-0.4-1.4,0s-0.4,1,0,1.4 l4,4c0.1,0.1,0.2,0.2,0.3,0.2C11.7,20,11.9,20,12,20s0.3,0,0.4-0.1c0.1-0.1,0.2-0.1,0.3-0.2l4-4C17.1,15.3,17.1,14.7,16.7,14.3z" />
|
|
63
|
+
</svg>
|
|
64
|
+
);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
export function CloseIcon({ size = 12, color = "currentColor" }: IconProps) {
|
|
68
|
+
return (
|
|
69
|
+
<svg width={size} height={size} viewBox="0 0 24 24" fill={color} aria-hidden="true">
|
|
70
|
+
<path d="M16.2,4H7.6c-2,0-3.7,1.6-3.7,3.7v8.7c0,2,1.6,3.7,3.7,3.7h8.7c2,0,3.7-1.6,3.7-3.7V7.7C19.9,5.7,18.3,4,16.2,4z M15,13.8 c0.4,0.4,0.4,1,0,1.4l-0.1,0.1c-0.4,0.3-1,0.3-1.3-0.1l-1.8-1.8L10,15.2c-0.4,0.4-1,0.4-1.4,0l-0.1-0.1c-0.3-0.4-0.3-1,0.1-1.3 l1.8-1.8l-1.7-1.8c-0.4-0.4-0.4-1,0-1.4l0.1-0.1c0.4-0.3,1-0.3,1.3,0.1l1.7,1.8l1.8-1.8c0.4-0.4,1-0.4,1.4,0l0.1,0.1 c0.3,0.4,0.3,1-0.1,1.3L13.3,12L15,13.8z" />
|
|
71
|
+
</svg>
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
// ============================================
|
|
76
|
+
// Tooltip — mirrors the admin sidebar pattern (CSS-only, group-hover).
|
|
77
|
+
// Positioned below the trigger; parent needs `group relative`.
|
|
78
|
+
// ============================================
|
|
79
|
+
|
|
80
|
+
export function BubbleTooltip({ children }: { children: ReactNode }) {
|
|
81
|
+
return (
|
|
82
|
+
<span
|
|
83
|
+
role="tooltip"
|
|
84
|
+
className="pointer-events-none absolute left-1/2 top-full z-50 mt-1.5 whitespace-nowrap rounded-md border border-white/10 bg-[#2a2d33] px-2.5 py-1.5 text-[11px] font-medium text-white shadow-lg opacity-0 transition-[opacity,margin] duration-150 ease-out group-hover/bb:opacity-100 group-hover/bb:mt-3"
|
|
85
|
+
style={{ transform: "translateX(-50%)" }}
|
|
86
|
+
>
|
|
87
|
+
{children}
|
|
88
|
+
</span>
|
|
89
|
+
);
|
|
90
|
+
}
|
|
@@ -69,6 +69,7 @@ export default function BuilderCanvas({ children }: BuilderCanvasProps) {
|
|
|
69
69
|
const setActiveViewport = useBuilderStore((s) => s.setActiveViewport);
|
|
70
70
|
const bgColor = useBuilderStore((s) => s.pageSettings.background_color);
|
|
71
71
|
const pageSlug = useBuilderStore((s) => s.pageSlug);
|
|
72
|
+
const clearSelection = useBuilderStore((s) => s.clearSelection);
|
|
72
73
|
|
|
73
74
|
// Refs for stable wheel/pan handlers — avoids re-creating callbacks on every zoom/pan change
|
|
74
75
|
const zoomRef = useRef(zoom);
|
|
@@ -288,6 +289,7 @@ export default function BuilderCanvas({ children }: BuilderCanvasProps) {
|
|
|
288
289
|
onMouseMove={handleMouseMove}
|
|
289
290
|
onMouseUp={handleMouseUp}
|
|
290
291
|
onMouseLeave={handleMouseUp}
|
|
292
|
+
onClick={clearSelection}
|
|
291
293
|
>
|
|
292
294
|
{/* Dot grid background */}
|
|
293
295
|
<div
|
|
@@ -173,9 +173,9 @@ export default function CanvasMinimap({
|
|
|
173
173
|
top: 8 * scale,
|
|
174
174
|
width: f.w,
|
|
175
175
|
height: (contentEstimateHeight - 40) * scale,
|
|
176
|
-
border: `1px solid ${f.active ? "rgba(
|
|
176
|
+
border: `1px solid ${f.active ? "rgba(53, 128, 249, 0.6)" : "rgba(255, 255, 255, 0.15)"}`,
|
|
177
177
|
borderRadius: 2,
|
|
178
|
-
backgroundColor: f.active ? "rgba(
|
|
178
|
+
backgroundColor: f.active ? "rgba(53, 128, 249, 0.08)" : "rgba(255, 255, 255, 0.03)",
|
|
179
179
|
}}
|
|
180
180
|
/>
|
|
181
181
|
))}
|