@morphika/andami 0.5.0 → 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.
Files changed (122) hide show
  1. package/README.md +151 -36
  2. package/app/admin/assets/page.tsx +6 -6
  3. package/app/admin/database/page.tsx +302 -302
  4. package/app/admin/error.tsx +53 -53
  5. package/app/admin/layout.tsx +320 -327
  6. package/app/admin/navigation/page.tsx +255 -255
  7. package/app/admin/pages/[slug]/page.tsx +6 -6
  8. package/app/admin/pages/page.tsx +11 -11
  9. package/app/admin/projects/page.tsx +14 -14
  10. package/app/admin/setup/page.tsx +1 -1
  11. package/app/admin/styles/page.tsx +1 -1
  12. package/components/admin/MetadataEditor.tsx +6 -6
  13. package/components/admin/nav-builder/NavBuilder.tsx +1 -1
  14. package/components/admin/nav-builder/NavBuilderGrid.tsx +3 -3
  15. package/components/admin/nav-builder/NavGridCell.tsx +48 -48
  16. package/components/admin/nav-builder/NavGridItem.tsx +4 -4
  17. package/components/admin/nav-builder/NavItemSettings.tsx +331 -331
  18. package/components/admin/nav-builder/NavItemTypePicker.tsx +102 -102
  19. package/components/admin/nav-builder/NavLivePreview.tsx +1 -1
  20. package/components/admin/nav-builder/NavMobileLivePreview.tsx +226 -226
  21. package/components/admin/nav-builder/NavMobileSettings.tsx +242 -242
  22. package/components/admin/nav-builder/NavSettingsFields.tsx +514 -514
  23. package/components/admin/setup-wizard/BrandingStep.tsx +3 -3
  24. package/components/admin/setup-wizard/DatabaseStep.tsx +2 -2
  25. package/components/admin/setup-wizard/DoneStep.tsx +1 -1
  26. package/components/admin/setup-wizard/SetupWizard.tsx +4 -4
  27. package/components/admin/setup-wizard/StorageStep.tsx +2 -2
  28. package/components/admin/setup-wizard/WelcomeStep.tsx +2 -2
  29. package/components/admin/styles/ColorsEditor.tsx +2 -2
  30. package/components/admin/styles/FontsEditor.tsx +6 -6
  31. package/components/admin/styles/GridLayoutEditor.tsx +9 -9
  32. package/components/admin/styles/LinksButtonsEditor.tsx +5 -5
  33. package/components/admin/styles/TypographyEditor.tsx +6 -6
  34. package/components/admin/styles/shared.tsx +68 -68
  35. package/components/blocks/AudioBlockRenderer.tsx +286 -0
  36. package/components/blocks/BeforeAfterBlockRenderer.tsx +274 -0
  37. package/components/blocks/MarqueeBlockRenderer.tsx +316 -0
  38. package/components/blocks/ProjectCarouselBlockRenderer.tsx +1 -1
  39. package/components/builder/BlockCardIcons.tsx +316 -227
  40. package/components/builder/BlockTypePicker.tsx +3 -1
  41. package/components/builder/BubbleIcons.tsx +90 -0
  42. package/components/builder/BuilderCanvas.tsx +2 -0
  43. package/components/builder/CanvasMinimap.tsx +2 -2
  44. package/components/builder/CoverSectionCanvas.tsx +363 -275
  45. package/components/builder/DeviceFrame.tsx +1 -1
  46. package/components/builder/DndWrapper.tsx +3 -3
  47. package/components/builder/InsertionLines.tsx +1 -1
  48. package/components/builder/SectionCardIcons.tsx +421 -320
  49. package/components/builder/SectionEditorBar.tsx +1 -1
  50. package/components/builder/SectionTypePicker.tsx +4 -4
  51. package/components/builder/SectionV2Canvas.tsx +20 -4
  52. package/components/builder/SectionV2Column.tsx +74 -68
  53. package/components/builder/SortableBlock.tsx +93 -73
  54. package/components/builder/SortableRow.tsx +27 -26
  55. package/components/builder/VirtualAssetGrid.tsx +2 -2
  56. package/components/builder/asset-browser/R2BrowserContent.tsx +34 -17
  57. package/components/builder/asset-browser/helpers.ts +4 -0
  58. package/components/builder/asset-browser/types.ts +2 -1
  59. package/components/builder/blockStyles.tsx +192 -173
  60. package/components/builder/color-picker/AlphaSlider.tsx +141 -141
  61. package/components/builder/color-picker/ColorInputs.tsx +105 -105
  62. package/components/builder/color-picker/EyedropperButton.tsx +74 -74
  63. package/components/builder/color-picker/HueSlider.tsx +124 -124
  64. package/components/builder/color-picker/SaturationCanvas.tsx +142 -142
  65. package/components/builder/color-picker/SwatchBar.tsx +93 -93
  66. package/components/builder/editors/AudioBlockEditor.tsx +242 -0
  67. package/components/builder/editors/BeforeAfterBlockEditor.tsx +360 -0
  68. package/components/builder/editors/ButtonBlockEditor.tsx +4 -4
  69. package/components/builder/editors/EnterAnimationPicker.tsx +2 -2
  70. package/components/builder/editors/HoverEffectPicker.tsx +2 -2
  71. package/components/builder/editors/ImageBlockEditor.tsx +2 -2
  72. package/components/builder/editors/ImageGridBlockEditor.tsx +4 -4
  73. package/components/builder/editors/MarqueeBlockEditor.tsx +621 -0
  74. package/components/builder/editors/ProjectCarouselBlockEditor.tsx +443 -443
  75. package/components/builder/editors/ProjectGridEditor.tsx +9 -9
  76. package/components/builder/editors/SpacerBlockEditor.tsx +5 -5
  77. package/components/builder/editors/StaggerSettings.tsx +109 -109
  78. package/components/builder/editors/TextBlockEditor.tsx +3 -3
  79. package/components/builder/editors/TextStylePicker.tsx +1 -1
  80. package/components/builder/editors/VideoBlockEditor.tsx +2 -2
  81. package/components/builder/editors/index.ts +11 -10
  82. package/components/builder/editors/shared.tsx +7 -7
  83. package/components/builder/live-preview/LiveAudioPreview.tsx +120 -0
  84. package/components/builder/live-preview/LiveBeforeAfterPreview.tsx +176 -0
  85. package/components/builder/live-preview/LiveImageGridPreview.tsx +10 -2
  86. package/components/builder/live-preview/LiveImagePreview.tsx +1 -1
  87. package/components/builder/live-preview/LiveMarqueePreview.tsx +39 -0
  88. package/components/builder/live-preview/LiveProjectCarouselPreview.tsx +1 -1
  89. package/components/builder/live-preview/LiveVideoPreview.tsx +1 -1
  90. package/components/builder/live-preview/ProjectCardWrapper.tsx +291 -291
  91. package/components/builder/settings-panel/AnimationTab.tsx +138 -138
  92. package/components/builder/settings-panel/BlockLayoutTab.tsx +7 -7
  93. package/components/builder/settings-panel/CardEntranceSection.tsx +114 -114
  94. package/components/builder/settings-panel/ColumnV2Settings.tsx +5 -5
  95. package/components/builder/settings-panel/CoverSectionLayoutTab.tsx +71 -71
  96. package/components/builder/settings-panel/CoverSectionSettings.tsx +335 -335
  97. package/components/builder/settings-panel/PageSettings.tsx +3 -3
  98. package/components/builder/settings-panel/ParallaxSlideSettings.tsx +2 -2
  99. package/components/builder/settings-panel/SectionV2AnimationTab.tsx +4 -4
  100. package/components/builder/settings-panel/SectionV2LayoutTab.tsx +356 -356
  101. package/components/builder/settings-panel/SectionV2Settings.tsx +14 -14
  102. package/components/builder/settings-panel/TRBLInputs.tsx +1 -1
  103. package/lib/animation/enter-types.ts +3 -0
  104. package/lib/animation/hover-effect-presets.ts +210 -210
  105. package/lib/animation/hover-effect-types.ts +3 -0
  106. package/lib/builder/block-registrations.ts +468 -335
  107. package/lib/builder/constants.ts +111 -111
  108. package/lib/builder/store-sections.ts +2 -2
  109. package/lib/builder/types-slices.ts +414 -414
  110. package/lib/builder/types.ts +6 -1
  111. package/lib/config/index.ts +27 -27
  112. package/lib/sanity/types.ts +156 -1
  113. package/lib/version.ts +1 -1
  114. package/package.json +1 -1
  115. package/sanity/schemas/blocks/audioBlock.ts +69 -0
  116. package/sanity/schemas/blocks/beforeAfterBlock.ts +121 -0
  117. package/sanity/schemas/blocks/index.ts +12 -9
  118. package/sanity/schemas/blocks/marqueeBlock.ts +292 -0
  119. package/sanity/schemas/index.ts +120 -111
  120. package/styles/admin.css +85 -85
  121. package/styles/animations.css +237 -237
  122. package/styles/base.css +114 -114
@@ -1,71 +1,71 @@
1
- "use client";
2
-
3
- import { useBuilderStore } from "../../../lib/builder/store";
4
- import type { CoverSection } from "../../../lib/sanity/types";
5
- import {
6
- SpacingIcon,
7
- OffsetIcon,
8
- BorderIcon,
9
- } from "../editors/section-icons";
10
- import { SettingsField, SettingsSection } from "../editors/shared";
11
- import { TRBLInputs } from "./TRBLInputs";
12
-
13
- interface CoverSectionLayoutTabProps {
14
- section: CoverSection;
15
- }
16
-
17
- export default function CoverSectionLayoutTab({ section }: CoverSectionLayoutTabProps) {
18
- const store = useBuilderStore();
19
- const s = section.settings;
20
-
21
- const update = (fields: Record<string, string | undefined>) => {
22
- store.updateCoverSettings(section._key, fields as Partial<typeof s>);
23
- };
24
-
25
- return (
26
- <>
27
- {/* Spacing (padding) */}
28
- <SettingsSection title="Spacing" defaultOpen icon={<SpacingIcon />}>
29
- <TRBLInputs
30
- top={s.spacing_top || ""}
31
- right={s.spacing_right || ""}
32
- bottom={s.spacing_bottom || ""}
33
- left={s.spacing_left || ""}
34
- onChange={(field, value) => update({ [`spacing_${field}`]: value || undefined })}
35
- />
36
- </SettingsSection>
37
-
38
- {/* Offset (margin) */}
39
- <SettingsSection title="Offset" defaultOpen={false} icon={<OffsetIcon />}>
40
- <TRBLInputs
41
- top={s.offset_top || ""}
42
- right={s.offset_right || ""}
43
- bottom={s.offset_bottom || ""}
44
- left={s.offset_left || ""}
45
- onChange={(field, value) => update({ [`offset_${field}`]: value || undefined })}
46
- />
47
- </SettingsSection>
48
-
49
- {/* Border Radius */}
50
- <SettingsSection title="Border" defaultOpen={false} icon={<BorderIcon />}>
51
- <SettingsField label="Radius">
52
- <div className="flex items-center gap-2">
53
- <input
54
- type="range"
55
- min={0}
56
- max={50}
57
- step={1}
58
- value={parseInt(s.border_radius || "0", 10) || 0}
59
- onMouseDown={() => store._pushSnapshot()}
60
- onChange={(e) => update({ border_radius: e.target.value === "0" ? undefined : e.target.value })}
61
- className="flex-1 accent-[#076bff]"
62
- />
63
- <span className="text-xs text-neutral-900 w-10 text-right tabular-nums">
64
- {parseInt(s.border_radius || "0", 10) || 0}px
65
- </span>
66
- </div>
67
- </SettingsField>
68
- </SettingsSection>
69
- </>
70
- );
71
- }
1
+ "use client";
2
+
3
+ import { useBuilderStore } from "../../../lib/builder/store";
4
+ import type { CoverSection } from "../../../lib/sanity/types";
5
+ import {
6
+ SpacingIcon,
7
+ OffsetIcon,
8
+ BorderIcon,
9
+ } from "../editors/section-icons";
10
+ import { SettingsField, SettingsSection } from "../editors/shared";
11
+ import { TRBLInputs } from "./TRBLInputs";
12
+
13
+ interface CoverSectionLayoutTabProps {
14
+ section: CoverSection;
15
+ }
16
+
17
+ export default function CoverSectionLayoutTab({ section }: CoverSectionLayoutTabProps) {
18
+ const store = useBuilderStore();
19
+ const s = section.settings;
20
+
21
+ const update = (fields: Record<string, string | undefined>) => {
22
+ store.updateCoverSettings(section._key, fields as Partial<typeof s>);
23
+ };
24
+
25
+ return (
26
+ <>
27
+ {/* Spacing (padding) */}
28
+ <SettingsSection title="Spacing" defaultOpen icon={<SpacingIcon />}>
29
+ <TRBLInputs
30
+ top={s.spacing_top || ""}
31
+ right={s.spacing_right || ""}
32
+ bottom={s.spacing_bottom || ""}
33
+ left={s.spacing_left || ""}
34
+ onChange={(field, value) => update({ [`spacing_${field}`]: value || undefined })}
35
+ />
36
+ </SettingsSection>
37
+
38
+ {/* Offset (margin) */}
39
+ <SettingsSection title="Offset" defaultOpen={false} icon={<OffsetIcon />}>
40
+ <TRBLInputs
41
+ top={s.offset_top || ""}
42
+ right={s.offset_right || ""}
43
+ bottom={s.offset_bottom || ""}
44
+ left={s.offset_left || ""}
45
+ onChange={(field, value) => update({ [`offset_${field}`]: value || undefined })}
46
+ />
47
+ </SettingsSection>
48
+
49
+ {/* Border Radius */}
50
+ <SettingsSection title="Border" defaultOpen={false} icon={<BorderIcon />}>
51
+ <SettingsField label="Radius">
52
+ <div className="flex items-center gap-2">
53
+ <input
54
+ type="range"
55
+ min={0}
56
+ max={50}
57
+ step={1}
58
+ value={parseInt(s.border_radius || "0", 10) || 0}
59
+ onMouseDown={() => store._pushSnapshot()}
60
+ onChange={(e) => update({ border_radius: e.target.value === "0" ? undefined : e.target.value })}
61
+ className="flex-1 accent-[#3580f9]"
62
+ />
63
+ <span className="text-xs text-neutral-900 w-10 text-right tabular-nums">
64
+ {parseInt(s.border_radius || "0", 10) || 0}px
65
+ </span>
66
+ </div>
67
+ </SettingsField>
68
+ </SettingsSection>
69
+ </>
70
+ );
71
+ }