File: D:/HostingSpaces/RMourik/bassol.nl/CMS/CMSWebParts/Ecommerce/Products/SimilarProductsBySale.ascx.cs
using System;
using System.Data;
using System.Collections;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using CMS.Controls;
using CMS.DocumentEngine;
using CMS.Helpers;
using CMS.PortalControls;
using CMS.SiteProvider;
using CMS.Membership;
public partial class CMSWebParts_Ecommerce_Products_SimilarProductsBySale : CMSAbstractWebPart
{
#region "Document properties"
/// <summary>
/// Site name.
/// </summary>
public string SiteName
{
get
{
return DataHelper.GetNotEmpty(GetValue("SiteName"), lstElem.SiteName);
}
set
{
SetValue("SiteName", value);
lstElem.SiteName = value;
}
}
/// <summary>
/// Nodes path.
/// </summary>
public string Path
{
get
{
return DataHelper.GetNotEmpty(GetValue("Path"), "/%");
}
set
{
SetValue("Path", value);
lstElem.Path = value;
}
}
/// <summary>
/// Maximal relative level.
/// </summary>
public int MaxRelativeLevel
{
get
{
return ValidationHelper.GetInteger(GetValue("MaxRelativeLevel"), lstElem.MaxRelativeLevel);
}
set
{
SetValue("MaxRelativeLevel", value);
lstElem.MaxRelativeLevel = value;
}
}
/// <summary>
/// Class names.
/// </summary>
public string ClassNames
{
get
{
return DataHelper.GetNotEmpty(GetValue("Classnames"), lstElem.ClassNames);
}
set
{
SetValue("ClassNames", value);
lstElem.ClassNames = value;
}
}
/// <summary>
/// Select top N items.
/// </summary>
public int SelectTopN
{
get
{
return ValidationHelper.GetInteger(GetValue("SelectTopN"), lstElem.SelectTopN);
}
set
{
SetValue("SelectTopN", value);
lstElem.SelectTopN = value;
}
}
/// <summary>
/// Where condition.
/// </summary>
public string WhereCondition
{
get
{
return DataHelper.GetNotEmpty(GetValue("WhereCondition"), lstElem.WhereCondition);
}
set
{
SetValue("WhereCondition", value);
lstElem.WhereCondition = GetWhereCondition(value);
}
}
/// <summary>
/// Order by clause.
/// </summary>
public string OrderBy
{
get
{
return DataHelper.GetNotEmpty(GetValue("OrderBy"), "SKUName");
}
set
{
SetValue("OrderBy", value);
lstElem.OrderBy = GetOrderByExpression(value);
}
}
/// <summary>
/// Select only published nodes.
/// </summary>
public bool SelectOnlyPublished
{
get
{
return ValidationHelper.GetBoolean(GetValue("SelectOnlyPublished"), lstElem.SelectOnlyPublished);
}
set
{
SetValue("SelectOnlyPublished", value);
lstElem.SelectOnlyPublished = value;
}
}
/// <summary>
/// Culture code.
/// </summary>
public string CultureCode
{
get
{
return DataHelper.GetNotEmpty(GetValue("CultureCode"), lstElem.CultureCode);
}
set
{
SetValue("CultureCode", value);
lstElem.CultureCode = value;
}
}
/// <summary>
/// Combine with default culture.
/// </summary>
public bool CombineWithDefaultCulture
{
get
{
return ValidationHelper.GetBoolean(GetValue("CombineWithDefaultCulture"), lstElem.CombineWithDefaultCulture);
}
set
{
SetValue("CombineWithDefaultCulture", value);
lstElem.CombineWithDefaultCulture = value;
}
}
#endregion
#region "Layout"
/// <summary>
/// Repeat columns.
/// </summary>
public int RepeatColumns
{
get
{
return ValidationHelper.GetInteger(GetValue("RepeatColumns"), lstElem.RepeatColumns);
}
set
{
SetValue("RepeatColumns", value);
lstElem.RepeatColumns = value;
}
}
/// <summary>
/// Repeat layout.
/// </summary>
public RepeatLayout RepeatLayout
{
get
{
return CMSDataList.GetRepeatLayout(DataHelper.GetNotEmpty(GetValue("RepeatLayout"), lstElem.RepeatLayout.ToString()));
}
set
{
SetValue("RepeatLayout", value.ToString());
lstElem.RepeatLayout = value;
}
}
/// <summary>
/// Repeat Direction.
/// </summary>
public RepeatDirection RepeatDirection
{
get
{
return CMSDataList.GetRepeatDirection(DataHelper.GetNotEmpty(GetValue("RepeatDirection"), lstElem.RepeatDirection.ToString()));
}
set
{
SetValue("RepeatDirection", value.ToString());
lstElem.RepeatDirection = value;
}
}
#endregion
#region "System settings"
/// <summary>
/// Gest or sest the cache item name.
/// </summary>
public override string CacheItemName
{
get
{
return base.CacheItemName;
}
set
{
base.CacheItemName = value;
lstElem.CacheItemName = value;
}
}
/// <summary>
/// Cache dependencies, each cache dependency on a new line.
/// </summary>
public override string CacheDependencies
{
get
{
return ValidationHelper.GetString(base.CacheDependencies, lstElem.CacheDependencies);
}
set
{
base.CacheDependencies = value;
lstElem.CacheDependencies = value;
}
}
/// <summary>
/// Gets or sets the cache minutes.
/// </summary>
public override int CacheMinutes
{
get
{
return base.CacheMinutes;
}
set
{
base.CacheMinutes = value;
lstElem.CacheMinutes = value;
}
}
/// <summary>
/// Gets or sets the value that indicates whether permissions should be checked.
/// </summary>
public bool CheckPermissions
{
get
{
return ValidationHelper.GetBoolean(GetValue("CheckPermissions"), lstElem.CheckPermissions);
}
set
{
SetValue("CheckPermissions", value);
lstElem.CheckPermissions = value;
}
}
#endregion
#region "Transformation properties"
/// <summary>
/// Gets or sets the name of the transforamtion which is used for displaying the results.
/// </summary>
public string TransformationName
{
get
{
return DataHelper.GetNotEmpty(GetValue("TransformationName"), lstElem.TransformationName);
}
set
{
SetValue("TransformationName", value);
lstElem.TransformationName = value;
}
}
/// <summary>
/// Gets or sets the name of the transforamtion which is used for displaying the alternate results.
/// </summary>
public string AlternatingTransformationName
{
get
{
return DataHelper.GetNotEmpty(GetValue("AlternatingTransformationName"), lstElem.AlternatingTransformationName);
}
set
{
SetValue("AlternatingTransformationName", value);
lstElem.AlternatingTransformationName = value;
}
}
#endregion
#region "Public properties"
/// <summary>
/// Hide control for zero rows.
/// </summary>
public bool HideControlForZeroRows
{
get
{
return ValidationHelper.GetBoolean(GetValue("HideControlForZeroRows"), lstElem.HideControlForZeroRows);
}
set
{
SetValue("HideControlForZeroRows", value);
lstElem.HideControlForZeroRows = value;
}
}
/// <summary>
/// Zero rows text.
/// </summary>
public string ZeroRowsText
{
get
{
return DataHelper.GetNotEmpty(GetValue("ZeroRowsText"), lstElem.ZeroRowsText);
}
set
{
SetValue("ZeroRowsText", value);
lstElem.ZeroRowsText = value;
}
}
#endregion
/// <summary>
/// Content loaded event handler.
/// </summary>
public override void OnContentLoaded()
{
base.OnContentLoaded();
SetupControl();
}
/// <summary>
/// Initializes the control properties.
/// </summary>
protected void SetupControl()
{
// In design mode is pocessing of control stoped
if (StopProcessing)
{
lstElem.StopProcessing = true;
}
else
{
// Hide web part if current document is not product
if (DocumentContext.CurrentPageInfo.NodeSKUID <= 0)
{
Visible = false;
lstElem.StopProcessing = true;
return;
}
lstElem.ControlContext = ControlContext;
// System settings
lstElem.CacheItemName = CacheItemName;
lstElem.CacheDependencies = CacheDependencies;
lstElem.CacheMinutes = CacheMinutes;
lstElem.CheckPermissions = CheckPermissions;
// Document properties
lstElem.SiteName = SiteName;
lstElem.ClassNames = ClassNames;
lstElem.Path = Path;
lstElem.MaxRelativeLevel = MaxRelativeLevel;
lstElem.SelectOnlyPublished = SelectOnlyPublished;
lstElem.CombineWithDefaultCulture = CombineWithDefaultCulture;
lstElem.CultureCode = CultureCode;
lstElem.SelectTopN = SelectTopN;
lstElem.WhereCondition = GetWhereCondition(WhereCondition);
lstElem.OrderBy = GetOrderByExpression(OrderBy);
// Layout
lstElem.RepeatColumns = RepeatColumns;
lstElem.RepeatDirection = RepeatDirection;
lstElem.RepeatLayout = RepeatLayout;
// Transformations
lstElem.AlternatingTransformationName = AlternatingTransformationName;
lstElem.TransformationName = TransformationName;
//// Public
lstElem.HideControlForZeroRows = HideControlForZeroRows;
lstElem.ZeroRowsText = ZeroRowsText;
}
}
/// <summary>
/// Reload data.
/// </summary>
public override void ReloadData()
{
base.ReloadData();
SetupControl();
lstElem.ReloadData(true);
}
/// <summary>
/// Returns where condition.
/// </summary>
/// <param name="customWhere">Custome where condition</param>
private string GetWhereCondition(string customWhere)
{
SiteInfo si = null;
// Get required site data
if (SiteName != "")
{
si = SiteInfoProvider.GetSiteInfo(SiteName);
}
else
{
si = SiteContext.CurrentSite;
}
if (si != null)
{
int siteID = si.SiteID;
int skuId = DocumentContext.CurrentPageInfo.NodeSKUID;
string where = "(NodeSKUID IN (SELECT OrderItemSKUID FROM COM_OrderItem JOIN COM_Order ON COM_OrderItem.OrderItemOrderID = COM_Order.OrderID JOIN COM_SKU ON COM_OrderItem.OrderItemSKUID = COM_SKU.SKUID WHERE (COM_SKU.SKUOptionCategoryID IS NULL) AND (COM_SKU.SKUEnabled = 1) AND (COM_Order.OrderSiteID = " + siteID + ") AND (COM_OrderItem.OrderItemSKUID <> " + skuId + ") AND (COM_Order.OrderID IN (SELECT OrderItemOrderID FROM COM_OrderItem WHERE OrderItemSKUID= " + skuId + "))))";
// Add custom WHERE condition
if (customWhere != "")
{
where += " AND (" + customWhere + ")";
}
return where;
}
return "";
}
/// <summary>
/// Returns ORDER BY expression.
/// </summary>
/// <param name="customOrderBy">Custom "Order by" expression</param>
private string GetOrderByExpression(string customOrderBy)
{
// Required "ORDER BY" expression
string orderBy = "(SELECT Count(OrderItemSKUID) FROM COM_OrderItem WHERE COM_OrderItem.OrderItemSKUID = NodeSKUID GROUP BY OrderItemSKUID) DESC";
// Add cutom "ORDER BY" expression
if (customOrderBy != "")
{
orderBy += ", " + customOrderBy;
}
return orderBy;
}
/// <summary>
/// OnPrerender override (Set visibility).
/// </summary>
protected override void OnPreRender(EventArgs e)
{
base.OnPreRender(e);
Visible = lstElem.Visible;
if (DataHelper.DataSourceIsEmpty(lstElem.DataSource) && (HideControlForZeroRows))
{
Visible = false;
}
}
/// <summary>
/// Clears cache.
/// </summary>
public override void ClearCache()
{
lstElem.ClearCache();
}
}