@yoamigo.com/core 0.3.16 → 0.3.17

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 (2) hide show
  1. package/dist/index.js +14 -6
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -3552,7 +3552,7 @@ function YaImage({
3552
3552
  fallbackSrc,
3553
3553
  fallbackAlt
3554
3554
  }) {
3555
- const { getValue, mode } = useContentStore();
3555
+ const { getValue, setValue, mode } = useContentStore();
3556
3556
  const containerRef = useRef8(null);
3557
3557
  const imgRef = useRef8(null);
3558
3558
  const [isSelected, setIsSelected] = useState7(false);
@@ -3560,12 +3560,14 @@ function YaImage({
3560
3560
  const [isSmallImage, setIsSmallImage] = useState7(false);
3561
3561
  const [isDropMode, setIsDropMode] = useState7(false);
3562
3562
  const [isDropHover, setIsDropHover] = useState7(false);
3563
+ const [previewOverride, setPreviewOverride] = useState7(null);
3563
3564
  const rawValue = getValue(fieldId);
3564
3565
  const imageData = parseImageValue(rawValue);
3565
- const src = imageData.src || fallbackSrc || PLACEHOLDER_SVG;
3566
- const altText = imageData.alt || alt || fallbackAlt || "";
3567
- const objectFit = imageData.objectFit || propObjectFit || "cover";
3568
- const objectPosition = getObjectPosition(imageData) || propObjectPosition || "50% 50%";
3566
+ const displayData = previewOverride || imageData;
3567
+ const src = displayData.src || fallbackSrc || PLACEHOLDER_SVG;
3568
+ const altText = displayData.alt || alt || fallbackAlt || "";
3569
+ const objectFit = displayData.objectFit || propObjectFit || "cover";
3570
+ const objectPosition = getObjectPosition(displayData) || propObjectPosition || "50% 50%";
3569
3571
  const handleClick = useCallback9(() => {
3570
3572
  if (mode !== "inline-edit") return;
3571
3573
  if (document.body.classList.contains("builder-selector-active")) return;
@@ -3598,17 +3600,23 @@ function YaImage({
3598
3600
  if (mode !== "inline-edit") return;
3599
3601
  const handleMessage2 = (event) => {
3600
3602
  if (event.data?.type === "YA_IMAGE_EDIT_COMPLETE" && event.data.fieldId === fieldId) {
3603
+ const value = event.data.value;
3604
+ setValue(fieldId, serializeImageValue(value), "user");
3605
+ setPreviewOverride(null);
3601
3606
  setIsSelected(false);
3602
3607
  }
3603
3608
  if (event.data?.type === "YA_IMAGE_EDIT_CANCEL" && event.data.fieldId === fieldId) {
3609
+ setPreviewOverride(null);
3604
3610
  setIsSelected(false);
3605
3611
  }
3606
3612
  if (event.data?.type === "YA_IMAGE_UPDATE_PREVIEW" && event.data.fieldId === fieldId) {
3613
+ const value = event.data.value;
3614
+ setPreviewOverride(value);
3607
3615
  }
3608
3616
  };
3609
3617
  window.addEventListener("message", handleMessage2);
3610
3618
  return () => window.removeEventListener("message", handleMessage2);
3611
- }, [mode, fieldId]);
3619
+ }, [mode, fieldId, setValue]);
3612
3620
  useEffect8(() => {
3613
3621
  if (mode !== "inline-edit") return;
3614
3622
  const handleDropModeMessage = (event) => {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@yoamigo.com/core",
3
- "version": "0.3.16",
3
+ "version": "0.3.17",
4
4
  "description": "Core components, router, and utilities for YoAmigo templates",
5
5
  "type": "module",
6
6
  "license": "SEE LICENSE IN LICENSE",