uCommerce - 将动态属性添加到订单行

时间:2013-07-04 22:07:20

标签: umbraco umbraco-ucommerce

我在基于可用的演示剃须刀店顶部构建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);
}
);
});

使用firebug,我检查了正在发布的数据

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

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

非常感谢任何帮助。

1 个答案:

答案 0 :(得分:0)

开箱即用,您无法通过API添加订单/订单项属性。虽然有效的JSON不会被API解释/使用,但您已指定已添加到的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);
}

如果您在使用它时遇到任何问题,请与我们联系。