merchi_product_editor
Version:
A React component for editing product images using Fabric.js
59 lines (58 loc) • 3.09 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
var react_1 = __importStar(require("react"));
var ImageZoomModal_1 = __importDefault(require("./ImageZoomModal"));
require("../styles/ProductEditor.css");
require("../styles/BottomPreviewDisplay.css");
var BottomPreviewDisplay = function (_a) {
var _b;
var images = _a.images;
var _c = (0, react_1.useState)(false), isModalOpen = _c[0], setIsModalOpen = _c[1];
var _d = (0, react_1.useState)(0), selectedPreviewIndex = _d[0], setSelectedPreviewIndex = _d[1];
var openModal = function (index) {
setSelectedPreviewIndex(index);
setIsModalOpen(true);
};
var closeModal = function () {
setIsModalOpen(false);
};
if (!images || images.length === 0) {
return null;
}
return (react_1.default.createElement(react_1.default.Fragment, null,
!isModalOpen && (react_1.default.createElement("div", { className: "bottom-preview-section" },
react_1.default.createElement("div", { className: "preview-images" }, images.map(function (preview, index) { return (react_1.default.createElement("div", { key: preview.id, className: "preview-image-box", onClick: function () { return openModal(index); }, style: {
backgroundImage: "url(".concat(preview.viewUrl, ")"),
backgroundSize: 'contain',
backgroundRepeat: 'no-repeat',
backgroundPosition: 'center center'
}, title: "Preview ".concat(index + 1) })); })))),
react_1.default.createElement(ImageZoomModal_1.default, { isOpen: isModalOpen, onClose: closeModal, imageUrl: ((_b = images[selectedPreviewIndex]) === null || _b === void 0 ? void 0 : _b.viewUrl) || '', productName: "Preview", totalImages: images.length, currentIndex: selectedPreviewIndex, allImages: images })));
};
exports.default = BottomPreviewDisplay;