@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.
- package/dist/index.js +14 -6
- 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
|
|
3566
|
-
const
|
|
3567
|
-
const
|
|
3568
|
-
const
|
|
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) => {
|