1

我在构建基于演示剃须刀商店顶部的 uCommerce 网站时遇到了问题http://thesitedoctor.co.uk/portfolio/avenue-clothingcom/

该演示使用 servicestack 和 ucommerceapi 来实现其购物篮功能。

我正在尝试在用户单击购买时将动态属性添加到购物篮(在订单行上)。我跟踪了 productpage.js 文件并修改了代码以添加一个新属性('message'):

function (data) {
var variant = data.Variant;
$.uCommerce.addToBasket(
{
    sku: variant.Sku,
    variantSku: variant.VariantSku,
    quantity: qty,
    message: $('#personalisedMessage').val()
},
function () {
    updateCartTotals(addToCartButton);
}
);
});

使用萤火虫,我检查了正在发布的数据

addToExistingLine: true
message: "this is a message"
quantity:"1" 
sku: "Product (options: none)"
variantSku:""

发布此内容不会导致错误,但我无法判断它是否有效 - 我无法在数据库中找到它,假设它将存储在 OrderProperty 表中。在这种情况下,我正在“购买”没有变化的产品。

非常感谢任何帮助。

4

1 回答 1

0

开箱即用,您不能像这样通过 API 添加订单/订单项属性。尽管 API 不会解释/使用有效的 JSON,但已指定您添加到的 API 有效负载。

相反,您需要做的是将您自己的方法添加到 API。为此,您需要从 IUCommerceApiService 实施一项服务,然后您就可以做您需要的事情。我在下面创建了一个示例(未经测试)并将其添加到演示商店,因为我认为这是一个有用的功能。

public class AddOrderLineProperty
{
    public int? OrderLineId { get; set; }

    public string Sku { get; set; }

    public string VariantSku { get; set; }

    public string Key { get; set; }

    public string Value { get; set; }
}
public class AddOrderLinePropertyResponse : IHasResponseStatus
{
    public AddOrderLinePropertyResponse() { }

    public AddOrderLinePropertyResponse(UCommerce.EntitiesV2.OrderLine line)
    {
        if (line == null)
        {
            UpdatedLine = new LineItem();
            return;
        }

        var currency = SiteContext.Current.CatalogContext.CurrentCatalog.PriceGroup.Currency;
        var lineTotal = new Money(line.Total.Value, currency);

        UpdatedLine = new LineItem()
        {
            OrderLineId = line.OrderLineId,
            Quantity = line.Quantity,
            Sku = line.Sku,
            VariantSku = line.VariantSku,
            Price = line.Price,
            ProductName = line.ProductName,
            Total = line.Total,
            FormattedTotal = lineTotal.ToString(),
            UnitDiscount = line.UnitDiscount,
            VAT = line.VAT,
            VATRate = line.VATRate
        };
    }

    public ResponseStatus ResponseStatus { get; set; }

    public LineItem UpdatedLine { get; set; }
}
public class AddOrderLinePropertyService : ServiceBase<AddOrderLineProperty>, IUCommerceApiService
{
    protected override object Run(AddOrderLineProperty request)
    {
        var orderLineId = request.OrderLineId;
        var sku = request.Sku;
        var variantSku = request.VariantSku;

        var orderLine = findOrderLine(orderLineId, sku, variantSku);
        addPropertyToOrderLine(orderLine, request.Key, request.Value);

        TransactionLibrary.ExecuteBasketPipeline();
        var newLine = findOrderLine(orderLineId, sku, variantSku);
        return new AddOrderLinePropertyResponse(newLine);
    }

    private void addPropertyToOrderLine(OrderLine orderLine, string key, string value)
    {
        if (orderLine == null)
            return;

        orderLine[key] = value;

        orderLine.Save();
    }

    private static OrderLine findOrderLine(int? orderLineId, string sku, string variantSku)
    {
        return orderLineId.HasValue
                            ? getOrderLineByOrderLineId(orderLineId)
                            : getOrderLineBySku(sku, variantSku);
    }

    private static OrderLine getOrderLineBySku(string sku, string variantSku)
    {
        return String.IsNullOrWhiteSpace(variantSku)
                            ? getOrderLines().FirstOrDefault(l => (l.Sku == sku))
                            : getOrderLines().FirstOrDefault(l => (l.Sku == sku && l.VariantSku == variantSku));
    }

    private static OrderLine getOrderLineByOrderLineId(int? orderLineId)
    {
        return getOrderLines().FirstOrDefault(l => l.OrderLineId == orderLineId);
    }

    private static ICollection<OrderLine> getOrderLines()
    {
        return TransactionLibrary.GetBasket().PurchaseOrder.OrderLines;
    }
}

您需要将新方法添加到 uCommerce.jQuery.js 中,如下所示:

addOrderLineProperty: function (options, onSuccess, onError) {
    var defaults = {
        orderLineId: 0
    };
    var extendedOptions = $.extend(defaults, options);
    callServiceStack({ AddOrderLineProperty: extendedOptions }, onSuccess, onError);
}

如果您在使用它时遇到任何问题,请告诉我。

蒂姆

于 2013-07-09T06:59:46.377 回答