using System;
using System.Collections.Generic;
using System.Linq;
using Kreta.DataAccess.Interfaces;
using Kreta.Framework;
using Kreta.Framework.Actions;
using Kreta.Framework.Collections;
using Kreta.Framework.Collections.Generic;
using Kreta.Framework.Entities;
using Kreta.Framework.Entities.Generic;
using Kreta.Framework.Exceptions;
namespace SDA.Kreta.Entities
{
///
/// Az UML modell KKTanarVegzettseg entitásának megvalósítása.
///
/// A kód teljes egészében generált, kézi módosítása nem megengedett!
[Entity("KKTanarVegzettseg")]
// alapértelmezett EntityHistoryMode
public class KKTanarVegzettseg : Entity, IKKTanarVegzettseg
{
internal protected KKTanarVegzettseg()
: base()
{
}
public class AttributeInfo
{
public const string Egyeb = "Egyeb";
public const string KKTanarVegzettsegId = "KKTanarVegzettsegId";
}
public class AttributeLengthInfo
{
public const int EgyebLength = 2147483647;
}
#region General
private KKTanarVegzettsegDA m_DA = new KKTanarVegzettsegDA();
protected static KKTanarVegzettseg FakeKKTanarVegzettseg { get; set; }
public static KKTanarVegzettseg GiveAnInstance()
{
KKTanarVegzettseg result = FakeKKTanarVegzettseg == null
? new KKTanarVegzettseg()
: (KKTanarVegzettseg)FakeKKTanarVegzettseg.MemberwiseClone();
result.Reset();
result.SetDefaultData();
return result;
}
protected void SetDefaultData()
{
if (UserContext.Instance != null)
{
if (UserContext.Instance.IntezmenyId > 0)
{
IntezmenyId = UserContext.Instance.IntezmenyId;
}
if (UserContext.Instance.AktivTanevId > 0)
{
TanevId = UserContext.Instance.AktivTanevId;
}
m_State = EntityState.Uninitialized;
}
}
protected override IEntityDataAccessor GetDataAccessor() { return m_DA; }
protected internal virtual IEntityDataAccessor InheritedDA { get { return null; } }
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
public static IEntityCollection LoadAll()
{
return LoadWithFilter("");
}
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
public static IEntityCollection LoadAll(ColumnFilterMode columnFilterMode, IEnumerable columns)
{
return LoadWithFilter("", columnFilterMode, columns);
}
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
public static IEntityCollection LoadWithFilter(string filter, Dictionary commandParameters = null)
{
var result = new EntityCollection();
new KKTanarVegzettsegDA().LoadWithFilter(result, filter, commandParameters);
return result;
}
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
public static IEntityCollection LoadWithFilter(string filter, ColumnFilterMode columnFilterMode, IEnumerable columns, Dictionary commandParameters = null)
{
var result = new EntityCollection();
new KKTanarVegzettsegDA().LoadWithFilter(result, filter, columnFilterMode, columns, commandParameters);
return result;
}
protected override void StoreOriginalValues()
{
base.StoreOriginalValues();
OriginalValues.Add("Egyeb", (Egyeb == null ? (object)DBNull.Value : (object)m_Egyeb));
OriginalValues.Add("KKTanarVegzettsegId", (KKTanarVegzettsegId == null ? (object)DBNull.Value : (object)m_KKTanarVegzettsegId));
OriginalValues.Add("AlkalmazottId", (m_AlkalmazottId < 0 ? (object)DBNull.Value : (object)m_AlkalmazottId));
OriginalValues.Add("IntezmenyId", (m_IntezmenyId < 0 ? (object)DBNull.Value : (object)m_IntezmenyId));
OriginalValues.Add("TanevId", (m_TanevId < 0 ? (object)DBNull.Value : (object)m_TanevId));
}
#endregion
#region Ellenőrzés
protected override void Validate(bool skipValidateAttributes = false)
{
base.Validate();
if (!skipValidateAttributes)
{
// korlátos hosszúságú mezők ellenőrzése...
if (m_Egyeb != null && m_Egyeb.Length > 2147483647)
{
throw new InvalidEntityAttributeException("KKTanarVegzettseg", "Egyeb", EntityAttributeError.TooLong);
}
}
// kötelező asszociációk ellenőrzése...
if (m_AlkalmazottId == -1) { throw new InvalidEntityAttributeException("KKTanarVegzettseg", "AlkalmazottId", EntityAttributeError.Empty); }
if (m_IntezmenyId == -1) { throw new InvalidEntityAttributeException("KKTanarVegzettseg", "IntezmenyId", EntityAttributeError.Empty); }
if (m_TanevId == -1) { throw new InvalidEntityAttributeException("KKTanarVegzettseg", "TanevId", EntityAttributeError.Empty); }
}
#endregion
#region Alaphelyzetbe állítás
protected override void Reset()
{
base.Reset();
// alaphelyzetbe állítjuk az egyszerű mezőket
this.m_Egyeb = null;
this.m_KKTanarVegzettsegId = null;
// alaphelyzetbe állítjuk az asszociációkból származó mezőket
this.m_AlkalmazottId = -1;
this.m_Alkalmazott = null; // Entity
this.m_KKTantargyKategoria = null; // EntityCollection
this.m_IntezmenyId = -1;
this.m_Intezmeny = null; // Entity
this.m_TanevId = -1;
this.m_Tanev = null; // Entity
}
#endregion
protected override void DeAssociateBeforeDelete(bool runHandler = false)
{
// Nem kaszkád törölhető asszociációk ellenőrzése, hogy üresek-e...
// Alkalmazott esetében mi mutatunk a másikra: startrole: 0..*, endrole: 1
if (this.KKTantargyKategoria.Count > 0)
{
throw new EntityDeleteFailedException("KKTanarVegzettseg", "KKTantargyKategoria", EntityUtil.GetAssociationDescription("T_KKTANTARGYKATEGORIA_OSSZES", "C_KKTANARVEGZETTSEGID")); // nincs kapcsolotabla
}
// Intezmeny esetében mi mutatunk a másikra: startrole: *, endrole: 1
// Tanev esetében mi mutatunk a másikra: startrole: *, endrole: 1
// kaszkád törlések...
}
#region Mezők és tulajdonságok
#region Egyszerű mezők
#region Egyeb
protected internal string m_Egyeb;
///
/// Nincs definiálva megjegyzés.
///
[EntityProperty("Egyeb", EntityPropertyBaseType.ValueType, typeof(string), EntityCopyMethod.ShallowCopy)]
public virtual string Egyeb
{
get
{
return m_Egyeb;
}
set
{
CheckModifyable();
if (m_Egyeb == value) return;
m_Egyeb = value;
FieldModified("Egyeb", value);
}
}
#endregion
#region KKTanarVegzettsegId
protected internal int? /* DictionaryItem */ m_KKTanarVegzettsegId;
///
/// Nincs definiálva megjegyzés.
///
[EntityProperty("KKTanarVegzettsegId", EntityPropertyBaseType.ValueType, typeof(int /* DictionaryItem */), EntityCopyMethod.ShallowCopy)]
[EntityDictionaryItemProperty("KKTanarVegzettsegId", "KKVegzettsegTipus", typeof(SDA.Kreta.Entities.KKVegzettsegTipus))]
public virtual int? /* DictionaryItem */ KKTanarVegzettsegId
{
get
{
return m_KKTanarVegzettsegId;
}
set
{
CheckModifyable();
if (m_KKTanarVegzettsegId == value) return;
m_KKTanarVegzettsegId = value;
FieldModified("KKTanarVegzettsegId", value);
}
}
#endregion
#endregion
#region Asszociációkkal kapcsolatos dolgok
protected internal virtual bool LoadByKKTantargyKategoriaId(int id)
{
return m_DA.LoadByKKTantargyKategoriaId(id, this);
}
#region KKTanarVegzettseg (0..*) -> Alkalmazott (1)
protected internal int m_AlkalmazottId = -1;
///
/// A(z) Alkalmazott asszociáció végpontjának ID-ja.
///
///
/// - Insert() előtt célszerű kitölteni
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
/// - LoadByID() felhozza ezt a mezőt
///
public virtual int AlkalmazottId
{
get
{
return InternalAlkalmazottId;
}
set
{
InternalAlkalmazottId = value;
}
}
///
/// Ez egy külön bejárat a DA számára
///
internal int InternalAlkalmazottId
{
get
{
if (m_Alkalmazott != null)
{
return m_Alkalmazott.ID;
}
else
{
return m_AlkalmazottId;// XXX az meg nem teljesen OK
}
}
set
{
CheckModifyable();
if (m_AlkalmazottId != value)
{
m_AlkalmazottId = value;
m_Alkalmazott = null;
FieldModified("AlkalmazottId", value);
}
}
}
///
/// Ez egy külön bejárat a DA számára
///
internal void ModifyAlkalmazott(Alkalmazott value)
{
m_AlkalmazottId = value != null ? value.ID : -1;
m_Alkalmazott = value;
FieldModified("AlkalmazottId", value != null ? (object)value.ID : DBNull.Value);
}
protected internal void SetAlkalmazott(Alkalmazott value)
{
m_Alkalmazott = value;
if (value != null)
{
m_AlkalmazottId = value.ID;
}
else
{
m_AlkalmazottId = -1;
}
}
protected Alkalmazott m_Alkalmazott = null;
IAlkalmazott IKKTanarVegzettseg.Alkalmazott
{
get { return Alkalmazott; }
set { Alkalmazott = value as Alkalmazott; }
}
///
/// Nincs definiálva megjegyzés.
///
///
/// Az UML modellben szereplő KKTanarVegzettseg és Alkalmazott entitások közötti asszociáció megvalósítása.
///
[EntityProperty("Alkalmazott", EntityPropertyBaseType.Entity, typeof(Alkalmazott), EntityCopyMethod.ShallowCopy)]
public virtual Alkalmazott Alkalmazott
{
get
{
if ((m_Alkalmazott == null) && (m_AlkalmazottId != -1))
{
SDA.Kreta.Entities.Alkalmazott partner = SDA.Kreta.Entities.Alkalmazott.GiveAnInstance();
partner.LoadByID(m_AlkalmazottId);
this.SetAlkalmazott(partner);
}
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
return m_Alkalmazott;
}
set
{
CheckModifyable();
if (value != null)
{
if ((m_Alkalmazott == null) || (value.ID != m_Alkalmazott.ID))
{
if (value.State != EntityState.Initialized)
{
throw new EntityStateException(value.State);
}
if ((this.State != EntityState.New))
{
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
SDA.Kreta.Entities.Alkalmazott_KKTanarVegzettseg_DA da = new Alkalmazott_KKTanarVegzettseg_DA(value);
da.AddItem(this);
this.SetAlkalmazott(value);
}
else
{
this.SetAlkalmazott(value);
}
FieldModified("AlkalmazottId", value.ID);
}
}
else
{
// ki kell törölni a kapcsolatot az adatbázisban
this.SetAlkalmazott(null);
UpdateAssociations();
FieldModified("AlkalmazottId", DBNull.Value);
}
}
}
#endregion
#region KKTanarVegzettseg (*) -> Intezmeny (1)
protected internal int m_IntezmenyId = -1;
///
/// A(z) Intezmeny asszociáció végpontjának ID-ja.
///
///
/// - Insert() előtt célszerű kitölteni
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
/// - LoadByID() felhozza ezt a mezőt
///
public virtual int IntezmenyId
{
get
{
return InternalIntezmenyId;
}
set
{
InternalIntezmenyId = value;
}
}
///
/// Ez egy külön bejárat a DA számára
///
internal int InternalIntezmenyId
{
get
{
if (m_Intezmeny != null)
{
return m_Intezmeny.ID;
}
else
{
return m_IntezmenyId;// XXX az meg nem teljesen OK
}
}
set
{
CheckModifyable();
if (m_IntezmenyId != value)
{
m_IntezmenyId = value;
m_Intezmeny = null;
FieldModified("IntezmenyId", value);
}
}
}
///
/// Ez egy külön bejárat a DA számára
///
internal void ModifyIntezmeny(Intezmeny value)
{
m_IntezmenyId = value != null ? value.ID : -1;
m_Intezmeny = value;
FieldModified("IntezmenyId", value != null ? (object)value.ID : DBNull.Value);
}
protected internal void SetIntezmeny(Intezmeny value)
{
m_Intezmeny = value;
if (value != null)
{
m_IntezmenyId = value.ID;
}
else
{
m_IntezmenyId = -1;
}
}
protected Intezmeny m_Intezmeny = null;
IIntezmeny IKKTanarVegzettseg.Intezmeny
{
get { return Intezmeny; }
set { Intezmeny = value as Intezmeny; }
}
///
/// Nincs definiálva megjegyzés.
///
///
/// Az UML modellben szereplő KKTanarVegzettseg és Intezmeny entitások közötti asszociáció megvalósítása.
///
[EntityProperty("Intezmeny", EntityPropertyBaseType.Entity, typeof(Intezmeny), EntityCopyMethod.ShallowCopy)]
public virtual Intezmeny Intezmeny
{
get
{
if ((m_Intezmeny == null) && (m_IntezmenyId != -1))
{
SDA.Kreta.Entities.Intezmeny partner = SDA.Kreta.Entities.Intezmeny.GiveAnInstance();
partner.LoadByID(m_IntezmenyId);
this.SetIntezmeny(partner);
}
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
return m_Intezmeny;
}
set
{
CheckModifyable();
if (value != null)
{
if ((m_Intezmeny == null) || (value.ID != m_Intezmeny.ID))
{
if (value.State != EntityState.Initialized)
{
throw new EntityStateException(value.State);
}
if ((this.State != EntityState.New))
{
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
SDA.Kreta.Entities.Intezmeny_KKTanarVegzettseg_DA da = new Intezmeny_KKTanarVegzettseg_DA(value);
da.AddItem(this);
this.SetIntezmeny(value);
}
else
{
this.SetIntezmeny(value);
}
FieldModified("IntezmenyId", value.ID);
}
}
else
{
// ki kell törölni a kapcsolatot az adatbázisban
this.SetIntezmeny(null);
UpdateAssociations();
FieldModified("IntezmenyId", DBNull.Value);
}
}
}
#endregion
#region KKTanarVegzettseg (*) -> Tanev (1)
protected internal int m_TanevId = -1;
///
/// A(z) Tanev asszociáció végpontjának ID-ja.
///
///
/// - Insert() előtt célszerű kitölteni
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
/// - LoadByID() felhozza ezt a mezőt
///
public virtual int TanevId
{
get
{
return InternalTanevId;
}
set
{
InternalTanevId = value;
}
}
///
/// Ez egy külön bejárat a DA számára
///
internal int InternalTanevId
{
get
{
if (m_Tanev != null)
{
return m_Tanev.ID;
}
else
{
return m_TanevId;// XXX az meg nem teljesen OK
}
}
set
{
CheckModifyable();
if (m_TanevId != value)
{
m_TanevId = value;
m_Tanev = null;
FieldModified("TanevId", value);
}
}
}
///
/// Ez egy külön bejárat a DA számára
///
internal void ModifyTanev(Tanev value)
{
m_TanevId = value != null ? value.ID : -1;
m_Tanev = value;
FieldModified("TanevId", value != null ? (object)value.ID : DBNull.Value);
}
protected internal void SetTanev(Tanev value)
{
m_Tanev = value;
if (value != null)
{
m_TanevId = value.ID;
}
else
{
m_TanevId = -1;
}
}
protected Tanev m_Tanev = null;
ITanev IKKTanarVegzettseg.Tanev
{
get { return Tanev; }
set { Tanev = value as Tanev; }
}
///
/// Nincs definiálva megjegyzés.
///
///
/// Az UML modellben szereplő KKTanarVegzettseg és Tanev entitások közötti asszociáció megvalósítása.
///
[EntityProperty("Tanev", EntityPropertyBaseType.Entity, typeof(Tanev), EntityCopyMethod.ShallowCopy)]
public virtual Tanev Tanev
{
get
{
if ((m_Tanev == null) && (m_TanevId != -1))
{
SDA.Kreta.Entities.Tanev partner = SDA.Kreta.Entities.Tanev.GiveAnInstance();
partner.LoadByID(m_TanevId);
this.SetTanev(partner);
}
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
return m_Tanev;
}
set
{
CheckModifyable();
if (value != null)
{
if ((m_Tanev == null) || (value.ID != m_Tanev.ID))
{
if (value.State != EntityState.Initialized)
{
throw new EntityStateException(value.State);
}
if ((this.State != EntityState.New))
{
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
SDA.Kreta.Entities.Tanev_KKTanarVegzettseg_DA da = new Tanev_KKTanarVegzettseg_DA(value);
da.AddItem(this);
this.SetTanev(value);
}
else
{
this.SetTanev(value);
}
FieldModified("TanevId", value.ID);
}
}
else
{
// ki kell törölni a kapcsolatot az adatbázisban
this.SetTanev(null);
UpdateAssociations();
FieldModified("TanevId", DBNull.Value);
}
}
}
#endregion
#region KKTanarVegzettseg (1) -> KKTantargyKategoria (0..*)
protected IAssociatedEntityCollection m_KKTantargyKategoria = null;
IReadOnlyList IKKTanarVegzettseg.KKTantargyKategoria => KKTantargyKategoria.Cast().ToList();
///
/// Nincs definiálva megjegyzés.
///
///
/// Az UML modellben szereplő KKTanarVegzettseg és KKTantargyKategoria entitások közötti asszociáció megvalósítása.
///
[EntityProperty("KKTantargyKategoria", EntityPropertyBaseType.EntityCollection, typeof(IAssociatedEntityCollection), EntityCopyMethod.DeepCopy, "KKTanarVegzettsegId")]
public virtual IAssociatedEntityCollection KKTantargyKategoria
{
get
{
if (m_KKTantargyKategoria == null)
{
m_KKTantargyKategoria = new AssociatedEntityCollection(
new KKTanarVegzettseg_KKTantargyKategoria_DA(this)
);
m_KKTantargyKategoria.Load();
}
return m_KKTantargyKategoria;
}
}
#endregion
#endregion
#endregion
}
}