@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
|
@@ -1,93 +1,93 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* SwatchBar — User palette swatches + common neutral colors.
|
|
5
|
-
*
|
|
6
|
-
* Integrated inside the color picker modal. Shows:
|
|
7
|
-
* - "Your Palette" row with user swatches + an "add to palette" button
|
|
8
|
-
* - "Common" row with standard neutrals (white → black)
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import { useCallback } from "react";
|
|
12
|
-
import type { SwatchBarProps } from "./types";
|
|
13
|
-
|
|
14
|
-
// Common neutral colors always available
|
|
15
|
-
const COMMON_COLORS = [
|
|
16
|
-
"#ffffff",
|
|
17
|
-
"#f5f5f5",
|
|
18
|
-
"#e5e5e5",
|
|
19
|
-
"#a3a3a3",
|
|
20
|
-
"#525252",
|
|
21
|
-
"#262626",
|
|
22
|
-
"#171717",
|
|
23
|
-
"#000000",
|
|
24
|
-
];
|
|
25
|
-
|
|
26
|
-
export default function SwatchBar({
|
|
27
|
-
value,
|
|
28
|
-
onSelect,
|
|
29
|
-
swatches = [],
|
|
30
|
-
}: SwatchBarProps) {
|
|
31
|
-
const handleSwatchClick = useCallback(
|
|
32
|
-
(hex: string) => {
|
|
33
|
-
onSelect(hex);
|
|
34
|
-
},
|
|
35
|
-
[onSelect]
|
|
36
|
-
);
|
|
37
|
-
|
|
38
|
-
return (
|
|
39
|
-
<div className="border-t border-neutral-200 pt-4">
|
|
40
|
-
{/* User palette */}
|
|
41
|
-
{swatches.length > 0 && (
|
|
42
|
-
<div className="mb-3">
|
|
43
|
-
<div className="flex items-center justify-between mb-2">
|
|
44
|
-
<span className="text-[10px] text-neutral-400 uppercase tracking-widest">
|
|
45
|
-
Your Palette
|
|
46
|
-
</span>
|
|
47
|
-
</div>
|
|
48
|
-
<div className="flex flex-wrap gap-1.5">
|
|
49
|
-
{swatches.map((s, i) => (
|
|
50
|
-
<button
|
|
51
|
-
key={s._key || `swatch-${i}`}
|
|
52
|
-
type="button"
|
|
53
|
-
onClick={() => handleSwatchClick(s.hex)}
|
|
54
|
-
title={`${s.name}: ${s.hex}`}
|
|
55
|
-
className={`w-8 h-8 rounded-lg cursor-pointer transition-all ${
|
|
56
|
-
value.toLowerCase() === s.hex.toLowerCase()
|
|
57
|
-
? "ring-2 ring-[#
|
|
58
|
-
: "border border-neutral-200 hover:border-neutral-400 hover:scale-110"
|
|
59
|
-
}`}
|
|
60
|
-
style={{ background: s.hex }}
|
|
61
|
-
/>
|
|
62
|
-
))}
|
|
63
|
-
</div>
|
|
64
|
-
</div>
|
|
65
|
-
)}
|
|
66
|
-
|
|
67
|
-
{/* Common colors */}
|
|
68
|
-
<div>
|
|
69
|
-
{swatches.length > 0 && (
|
|
70
|
-
<span className="text-[10px] text-neutral-400 uppercase tracking-widest block mb-2">
|
|
71
|
-
Common
|
|
72
|
-
</span>
|
|
73
|
-
)}
|
|
74
|
-
<div className="flex gap-1">
|
|
75
|
-
{COMMON_COLORS.map((c) => (
|
|
76
|
-
<button
|
|
77
|
-
key={c}
|
|
78
|
-
type="button"
|
|
79
|
-
onClick={() => handleSwatchClick(c)}
|
|
80
|
-
title={c.toUpperCase()}
|
|
81
|
-
className={`w-6 h-6 rounded-md cursor-pointer transition-all ${
|
|
82
|
-
value.toLowerCase() === c
|
|
83
|
-
? "ring-2 ring-[#
|
|
84
|
-
: "border border-neutral-200 hover:border-neutral-400 hover:scale-110"
|
|
85
|
-
}`}
|
|
86
|
-
style={{ background: c }}
|
|
87
|
-
/>
|
|
88
|
-
))}
|
|
89
|
-
</div>
|
|
90
|
-
</div>
|
|
91
|
-
</div>
|
|
92
|
-
);
|
|
93
|
-
}
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* SwatchBar — User palette swatches + common neutral colors.
|
|
5
|
+
*
|
|
6
|
+
* Integrated inside the color picker modal. Shows:
|
|
7
|
+
* - "Your Palette" row with user swatches + an "add to palette" button
|
|
8
|
+
* - "Common" row with standard neutrals (white → black)
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { useCallback } from "react";
|
|
12
|
+
import type { SwatchBarProps } from "./types";
|
|
13
|
+
|
|
14
|
+
// Common neutral colors always available
|
|
15
|
+
const COMMON_COLORS = [
|
|
16
|
+
"#ffffff",
|
|
17
|
+
"#f5f5f5",
|
|
18
|
+
"#e5e5e5",
|
|
19
|
+
"#a3a3a3",
|
|
20
|
+
"#525252",
|
|
21
|
+
"#262626",
|
|
22
|
+
"#171717",
|
|
23
|
+
"#000000",
|
|
24
|
+
];
|
|
25
|
+
|
|
26
|
+
export default function SwatchBar({
|
|
27
|
+
value,
|
|
28
|
+
onSelect,
|
|
29
|
+
swatches = [],
|
|
30
|
+
}: SwatchBarProps) {
|
|
31
|
+
const handleSwatchClick = useCallback(
|
|
32
|
+
(hex: string) => {
|
|
33
|
+
onSelect(hex);
|
|
34
|
+
},
|
|
35
|
+
[onSelect]
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
return (
|
|
39
|
+
<div className="border-t border-neutral-200 pt-4">
|
|
40
|
+
{/* User palette */}
|
|
41
|
+
{swatches.length > 0 && (
|
|
42
|
+
<div className="mb-3">
|
|
43
|
+
<div className="flex items-center justify-between mb-2">
|
|
44
|
+
<span className="text-[10px] text-neutral-400 uppercase tracking-widest">
|
|
45
|
+
Your Palette
|
|
46
|
+
</span>
|
|
47
|
+
</div>
|
|
48
|
+
<div className="flex flex-wrap gap-1.5">
|
|
49
|
+
{swatches.map((s, i) => (
|
|
50
|
+
<button
|
|
51
|
+
key={s._key || `swatch-${i}`}
|
|
52
|
+
type="button"
|
|
53
|
+
onClick={() => handleSwatchClick(s.hex)}
|
|
54
|
+
title={`${s.name}: ${s.hex}`}
|
|
55
|
+
className={`w-8 h-8 rounded-lg cursor-pointer transition-all ${
|
|
56
|
+
value.toLowerCase() === s.hex.toLowerCase()
|
|
57
|
+
? "ring-2 ring-[#3580f9] ring-offset-1 ring-offset-white"
|
|
58
|
+
: "border border-neutral-200 hover:border-neutral-400 hover:scale-110"
|
|
59
|
+
}`}
|
|
60
|
+
style={{ background: s.hex }}
|
|
61
|
+
/>
|
|
62
|
+
))}
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
65
|
+
)}
|
|
66
|
+
|
|
67
|
+
{/* Common colors */}
|
|
68
|
+
<div>
|
|
69
|
+
{swatches.length > 0 && (
|
|
70
|
+
<span className="text-[10px] text-neutral-400 uppercase tracking-widest block mb-2">
|
|
71
|
+
Common
|
|
72
|
+
</span>
|
|
73
|
+
)}
|
|
74
|
+
<div className="flex gap-1">
|
|
75
|
+
{COMMON_COLORS.map((c) => (
|
|
76
|
+
<button
|
|
77
|
+
key={c}
|
|
78
|
+
type="button"
|
|
79
|
+
onClick={() => handleSwatchClick(c)}
|
|
80
|
+
title={c.toUpperCase()}
|
|
81
|
+
className={`w-6 h-6 rounded-md cursor-pointer transition-all ${
|
|
82
|
+
value.toLowerCase() === c
|
|
83
|
+
? "ring-2 ring-[#3580f9] ring-offset-1 ring-offset-white"
|
|
84
|
+
: "border border-neutral-200 hover:border-neutral-400 hover:scale-110"
|
|
85
|
+
}`}
|
|
86
|
+
style={{ background: c }}
|
|
87
|
+
/>
|
|
88
|
+
))}
|
|
89
|
+
</div>
|
|
90
|
+
</div>
|
|
91
|
+
</div>
|
|
92
|
+
);
|
|
93
|
+
}
|