public void Update(string navn, int maksAntallElever, int avdelingId, IList <int> eleverIds, IList <int> ansatteIds) { if (Navn != navn) { Navn = navn; IsChanged = true; } if (MaksAntallElever != maksAntallElever) { MaksAntallElever = maksAntallElever; IsChanged = true; } if (Avdeling == null || Avdeling.Id != avdelingId) { Avdeling = Avdeling.GetById(avdelingId); IsChanged = true; } var eleverIdsOld = Elevs.OrderBy(elev => elev.Id).Select(elev => elev.Id).ToList(); if (eleverIdsOld.Count != eleverIds.Count || eleverIdsOld.SequenceEqual(eleverIds.OrderBy(i => i)) == false) { Elevs.Clear(); foreach (var elevId in eleverIds) { Elevs.Add(Elev.GetById(elevId)); } IsChanged = true; } var ansattIdsOld = Ansatts.OrderBy(ansatt => ansatt.Id).Select(ansatt => ansatt.Id).ToList(); if (ansattIdsOld.Count != ansatteIds.Count || ansattIdsOld.SequenceEqual(ansatteIds.OrderBy(i => i)) == false) { Ansatts.Clear(); foreach (var ansattId in ansatteIds) { Ansatts.Add(Ansatt.GetById(ansattId)); } IsChanged = true; } }
private void Copy(Avdeling copyFrom, TimeplanEntities db) { Navn = copyFrom.Navn; fk_AvdelingslederAnsattId = copyFrom.AvdelingsLeder.Id; Klasses.Clear(); foreach (var klasse in copyFrom.Klasses) { Klasses.Add(Klasse.GetById(klasse.Id, db)); } Ansatts.Clear(); foreach (var ansatt in copyFrom.Ansatts) { Ansatts.Add(Ansatt.GetById(ansatt.Id, db)); } }
public void Update(string navn, decimal stillingsStørrelse, string tlfNr, int avdelingId, int stillingsTypeId, IList <int> jobberIKlasserIds, IList <int> jobberISfosIds /*, IList<int> avdelingsLederIAvdelingIds , int varslesAvAnsattId, IList<int> varslerTilAnsatteIds*/) { if (Navn != navn) { Navn = navn; IsChanged = true; } if (Stillingsstørrelse != stillingsStørrelse) { Stillingsstørrelse = stillingsStørrelse; IsChanged = true; } if (Tlfnr != tlfNr) { Tlfnr = tlfNr; IsChanged = true; } if (Avdeling == null || Avdeling.Id != avdelingId) { Avdeling = Avdeling.GetById(avdelingId); IsChanged = true; } if (StillingsType == null || StillingsType.Id != stillingsTypeId) { StillingsType = StillingsType.GetById(stillingsTypeId); IsChanged = true; } var jobberIKlasserIdsOld = JobberIKlasser.OrderBy(klasse => klasse.Id).Select(klasse => klasse.Id).ToList(); if (jobberIKlasserIdsOld.Count != jobberIKlasserIds.Count || jobberIKlasserIdsOld.SequenceEqual(jobberIKlasserIds.OrderBy(i => i)) == false) { JobberIKlasser.Clear(); foreach (var klasseId in jobberIKlasserIds) { JobberIKlasser.Add(Klasse.GetById(klasseId)); } IsChanged = true; } var jobberISfosIdsOld = JobberISfos.OrderBy(sfo => sfo.Id).Select(sfo => sfo.Id).ToList(); if (jobberISfosIdsOld.Count != jobberISfosIds.Count || jobberISfosIdsOld.SequenceEqual(jobberISfosIds.OrderBy(i => i)) == false) { JobberISfos.Clear(); foreach (var sfoId in jobberISfosIds) { JobberISfos.Add(Sfo.GetById(sfoId)); } IsChanged = true; } //var avdelingsLederIAvdelingsIdsOld = AvdelingsLederIAvdelinger.OrderBy(avdeling => avdeling.Id).Select(avdeling => avdeling.Id).ToList(); //if (avdelingsLederIAvdelingsIdsOld.Count != avdelingsLederIAvdelingIds.Count // || avdelingsLederIAvdelingsIdsOld.SequenceEqual(avdelingsLederIAvdelingIds.OrderBy(i => i)) == false) //{ // AvdelingsLederIAvdelinger.Clear(); // foreach (var id in avdelingsLederIAvdelingIds) // { // AvdelingsLederIAvdelinger.Add(Avdeling.GetById(id)); // } // IsChanged = true; //} //if ((fk_VarslesAvAnsattId != null && fk_VarslesAvAnsattId != varslesAvAnsattId) // || (fk_VarslesAvAnsattId == null && varslesAvAnsattId != 0)) //{ // VarslesAvAnsatt = varslesAvAnsattId > 0 ? GetById(varslesAvAnsattId) : null; // IsChanged = true; //} //var varslerTilAnsatteIdsOld = VarslerTilAnsatte.Select(ansatt => ansatt.Id).ToList(); //if (varslerTilAnsatteIdsOld.Count != varslerTilAnsatteIds.Count // || varslerTilAnsatteIdsOld.SequenceEqual(varslerTilAnsatteIds) == false) //{ // VarslerTilAnsatte.Clear(); // foreach (var ansattId in varslerTilAnsatteIds) // { // VarslerTilAnsatte.Add(GetById(ansattId)); // } // IsChanged = true; //} }