///////////////////////////////////////////////////////////
// RegionList.cs
// Implementation of Class RegionList
// CSLA type: Read only collection
// Created on: 10-Nov-2004
// Object design: John
// Coded: 10-Nov-2004
///////////////////////////////////////////////////////////
using System;
using System.Data;
using GZTW.Data;
using CSLA.Data;
using CSLA;
namespace GZTW.AyaNova.BLL
{
#pragma warning disable 1591
///
/// Read only list of objects representing objects.
/// Used for grids and reporting.
///
[Serializable]
public class RegionList : ReadOnlyCollectionBase
{
#region Data structure
///
/// Properties
///
[Serializable]
public struct RegionListInfo
{
internal GridNameValueCellItem mName; //and ID
[SqlColumnNameAttribute("","aRegion.aID")]
public GridNameValueCellItem LT_Region_Label_Name
{
get
{
return mName;
}
}
///
///
///
///
public bool Equals(RegionListInfo obj)
{
return this.mName.Value.Equals(obj.mName.Value);
}
}//end RegionListInfo
#endregion
#region Constructor
///
///
///
protected RegionList()
{
// AllowSort=false;
// AllowFind=true;
// AllowEdit=false;
// AllowNew=false;
// AllowRemove=false;
}
#endregion
#region Business properties and methods
///
/// Get item by index
///
///
public RegionListInfo this[int Item]
{
get
{
return (RegionListInfo) List[Item];
}
}
///
/// Returns display text that matches passed in itemid value
///
///
public string this[Guid ItemID]
{
get
{
foreach (RegionListInfo child in List)
{
if (child.mName.Value == ItemID) return child.mName.Display;
}
return "Missing: "+ItemID.ToString();
}
}
#endregion
#region contains
///
/// Check if item in collection
///
///
public bool Contains(RegionListInfo obj)
{
foreach (RegionListInfo child in List)
{
if(child.Equals(obj)) return true;
}
return false;
}
//case 2072
///
/// Check if item in collection by Id
///
///
public bool Contains(Guid Id)
{
foreach (RegionListInfo child in List)
{
if (child.LT_Region_Label_Name.Value.Equals(Id)) return true;
}
return false;
}
#endregion
#region Static methods
///
/// Get list by criteria
///
/// Use AyaNova UI to easily build xmlCriteria and Ctrl-Alt-g keyboard command to display it for use in your code
/// list of objects
public static RegionList GetList(string xmlCriteria)
{
return (RegionList) DataPortal.Fetch(new Criteria(xmlCriteria));
}
///
/// Return an empty list
/// used for initializing grid
///
///
public static RegionList GetEmptyList()
{
return new RegionList();
}
#endregion
#region DAL DATA ACCESS
///
///
protected override void DataPortal_Fetch(object Criteria)
{
Criteria crit = (Criteria)Criteria;
SafeDataReader dr = null;
try
{
dr=DBUtil.GetReaderFromSQLString(
//************************************************************
"SELECT aRegion.aID, aRegion.aName " +
"FROM aRegion " +
AyaBizUtils.GetGridColumnCriteria(crit.CriteriaXML,true) + " " +
AyaBizUtils.GetGridSortOrderColumns(crit.CriteriaXML)
//************************************************************
);
while(dr.Read())
{
//*******************************************
RegionListInfo info=new RegionListInfo();
info.mName = new GridNameValueCellItem(
dr.GetGuid("aID"),
dr.GetString("aName"),
RootObjectTypes.Region);
InnerList.Add(info);
//*******************************************
}
}
finally
{
if(dr!=null) dr.Close();
}
}
#endregion
#region criteria
///
/// Criteria for identifying existing object
///
[Serializable]
private class Criteria
{
public string CriteriaXML;
public Criteria( string _CriteriaXML)
{
CriteriaXML=_CriteriaXML;
}
}
#endregion
}//end RegionList
#pragma warning restore 1591
}//end namespace GZTW.AyaNova.BLL