private void ChangeKeyLogic() { if (!string.IsNullOrEmpty(SelectedCompanyType.CompanyTypeID)) {//check to see if key is part of the current itemList... CompanyType query = CompanyTypeList.Where(item => item.CompanyTypeID == SelectedCompanyType.CompanyTypeID && item.AutoID != SelectedCompanyType.AutoID).FirstOrDefault(); if (query != null) {//revert it back SelectedCompanyType.CompanyTypeID = SelectedCompanyTypeMirror.CompanyTypeID; //change to the newly selected item... SelectedCompanyType = query; return; } //it is not part of the existing list try to fetch it from the db... CompanyTypeList = GetCompanyTypeByID(SelectedCompanyType.CompanyTypeID); if (CompanyTypeList.Count == 0)//it was not found do new record required logic... { NotifyNewRecordNeeded("Record " + SelectedCompanyType.CompanyTypeID + " Does Not Exist. Create A New Record?"); } else { SelectedCompanyType = CompanyTypeList.FirstOrDefault(); } } else { string errorMessage = "ID Is Required."; NotifyMessage(errorMessage); //revert back to the value it was before it was changed... if (SelectedCompanyType.CompanyTypeID != SelectedCompanyTypeMirror.CompanyTypeID) { SelectedCompanyType.CompanyTypeID = SelectedCompanyTypeMirror.CompanyTypeID; } } }
private void OnSearchResult(object sender, NotificationEventArgs <BindingList <CompanyType> > e) { if (e.Data != null && e.Data.Count > 0) { CompanyTypeList = e.Data; SelectedCompanyType = CompanyTypeList.FirstOrDefault(); Dirty = false; AllowCommit = false; } UnregisterToReceiveMessages <BindingList <CompanyType> >(MessageTokens.CompanyTypeSearchToken.ToString(), OnSearchResult); }