UNPKG

@shopify/hydrogen-react

Version:

React components, hooks, and utilities for creating custom Shopify storefronts

65 lines (64 loc) 2.42 kB
"use strict"; Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" }); const jsxRuntime = require("react/jsx-runtime"); const Money = require("./Money.js"); const flattenConnection = require("./flatten-connection.js"); function ProductPrice(props) { var _a, _b, _c, _d, _e, _f; const { priceType = "regular", variantId, valueType = "min", data: product, ...passthroughProps } = props; if (product == null) { throw new Error(`<ProductPrice/> requires a product as the 'data' prop`); } let price; let measurement; const variant = variantId ? flattenConnection.flattenConnection((product == null ? void 0 : product.variants) ?? {}).find( (variant2) => (variant2 == null ? void 0 : variant2.id) === variantId ) ?? null : null; const variantPriceProperty = valueType === "max" ? "maxVariantPrice" : "minVariantPrice"; if (priceType === "compareAt") { if (variantId && variant) { price = variant.compareAtPrice; } else { price = (_a = product == null ? void 0 : product.compareAtPriceRange) == null ? void 0 : _a[variantPriceProperty]; } let priceAsNumber; if (variantId && variant) { priceAsNumber = parseFloat(((_b = variant.price) == null ? void 0 : _b.amount) ?? "0"); } else { priceAsNumber = parseFloat( ((_d = (_c = product == null ? void 0 : product.priceRange) == null ? void 0 : _c[variantPriceProperty]) == null ? void 0 : _d.amount) ?? "0" ); } const compareAtPriceAsNumber = parseFloat((price == null ? void 0 : price.amount) ?? "0"); if (priceAsNumber >= compareAtPriceAsNumber) { return null; } } else { if (variantId && variant) { price = variant.price; if (valueType === "unit") { price = variant.unitPrice; measurement = variant.unitPriceMeasurement; } } else if (valueType === "max") { price = (_e = product.priceRange) == null ? void 0 : _e.maxVariantPrice; } else { price = (_f = product.priceRange) == null ? void 0 : _f.minVariantPrice; } } if (!price) { return null; } if (measurement) { return /* @__PURE__ */ jsxRuntime.jsx(Money.Money, { ...passthroughProps, data: price, measurement }); } return /* @__PURE__ */ jsxRuntime.jsx(Money.Money, { ...passthroughProps, data: price }); } exports.ProductPrice = ProductPrice; //# sourceMappingURL=ProductPrice.js.map