public static Common.Models.Opportunities.OpportunityContact Enable(
     Transaction t,
     Common.Models.Opportunities.OpportunityContact model,
     Common.Models.Account.Users enabler)
 {
     return(Enable(model, enabler, t.Connection, false));
 }
 public static Common.Models.Opportunities.OpportunityContact Edit(
     Transaction t,
     Common.Models.Opportunities.OpportunityContact model,
     Common.Models.Account.Users modifier)
 {
     return(Edit(model, modifier, t.Connection, false));
 }
 public static Common.Models.Opportunities.OpportunityContact Create(
     Transaction t,
     Common.Models.Opportunities.OpportunityContact model,
     Common.Models.Account.Users creator)
 {
     return(Create(model, creator, t.Connection, false));
 }
        public static Common.Models.Opportunities.OpportunityContact Disable(
            Common.Models.Opportunities.OpportunityContact model,
            Common.Models.Account.Users disabler,
            IDbConnection conn   = null,
            bool closeConnection = true)
        {
            model.DisabledBy = disabler;
            model.Disabled   = DateTime.UtcNow;

            DataHelper.Disable <Common.Models.Opportunities.OpportunityContact,
                                DBOs.Opportunities.OpportunityContact>("opportunity_contact", disabler.PId.Value, model.Id, conn, closeConnection);

            return(model);
        }
        public static Common.Models.Opportunities.OpportunityContact Create(
            Common.Models.Opportunities.OpportunityContact model,
            Common.Models.Account.Users creator,
            IDbConnection conn   = null,
            bool closeConnection = true)
        {
            Common.Models.Opportunities.OpportunityContact orig =
                DataHelper.Get <Common.Models.Opportunities.OpportunityContact, DBOs.Opportunities.OpportunityContact>(
                    "SELECT * FROM \"opportunity_contact\" WHERE\"opportunity_id\"=@OpportunityId AND \"contact_id\"=@ContactId",
                    new { OpportunityId = model.Opportunity.Id.Value, ContactId = model.Contact.Id.Value }, conn, closeConnection);

            if (orig != null)
            {
                if (orig.Disabled.HasValue || orig.DisabledBy != null)
                {
                    model.Id = orig.Id;
                    orig     = Edit(model, creator, conn, false);
                    orig     = Enable(model, creator, conn, false);
                }
            }
            else
            {
                model.Created   = model.Modified = DateTime.UtcNow;
                model.CreatedBy = model.ModifiedBy = creator;

                DBOs.Opportunities.OpportunityContact dbo = Mapper.Map <DBOs.Opportunities.OpportunityContact>(model);

                conn = DataHelper.OpenIfNeeded(conn);

                if (conn.Execute("INSERT INTO \"opportunity_contact\" (\"opportunity_id\", \"contact_id\", " +
                                 "\"utc_created\", \"utc_modified\", \"created_by_user_pid\", \"modified_by_user_pid\") " +
                                 "VALUES (@OpportunityId, @ContactId, " +
                                 "@UtcCreated, @UtcModified, @CreatedByUserPId, @ModifiedByUserPId)",
                                 dbo) > 0)
                {
                    model.Id = conn.Query <DBOs.Opportunities.OpportunityContact>("SELECT currval(pg_get_serial_sequence('opportunity_contact', 'id')) AS \"id\"").Single().Id;
                }
            }
            DataHelper.Close(conn, closeConnection);

            return(model);
        }
        public static Common.Models.Opportunities.OpportunityContact Edit(
            Common.Models.Opportunities.OpportunityContact model,
            Common.Models.Account.Users modifier,
            IDbConnection conn   = null,
            bool closeConnection = true)
        {
            model.ModifiedBy = modifier;
            model.Modified   = DateTime.UtcNow;
            DBOs.Opportunities.OpportunityContact dbo = Mapper.Map <DBOs.Opportunities.OpportunityContact>(model);

            conn = DataHelper.OpenIfNeeded(conn);

            conn.Execute("UPDATE \"opportunity_contact\" SET " +
                         "\"opportunity_id\"=@OpportunityId, \"contact_id\"=@ContactId, " +
                         "\"utc_modified\"=@UtcModified, \"modified_by_user_pid\"=@ModifiedByUserPId " +
                         "WHERE \"id\"=@Id", dbo);

            DataHelper.Close(conn, closeConnection);

            return(model);
        }
        public ActionResult Edit(long id, ViewModels.Opportunities.OpportunityViewModel viewModel)
        {
            Common.Models.Account.Users             currentUser;
            Common.Models.Opportunities.Opportunity model;

            using (Data.Transaction trans = Data.Transaction.Create(true))
            {
                try
                {
                    Common.Models.Leads.Lead lead;
                    currentUser = Data.Account.Users.Get(trans, User.Identity.Name);
                    Common.Models.Leads.Lead oldLead = Data.Leads.Lead.Get(trans, viewModel.Lead.Id.Value);

                    lead     = Mapper.Map <Common.Models.Leads.Lead>(viewModel.Lead);
                    lead.Fee = Mapper.Map <Common.Models.Leads.LeadFee>(viewModel.Lead.Fee);

                    if (oldLead.Fee != null)
                    {
                        lead.Fee = Data.Leads.LeadFee.Edit(trans, lead.Fee, currentUser);
                    }
                    else
                    {
                        lead.Fee = Data.Leads.LeadFee.Create(trans, lead.Fee, currentUser);
                    }

                    lead = Data.Leads.Lead.Edit(trans, lead, currentUser);

                    model = Mapper.Map <Common.Models.Opportunities.Opportunity>(viewModel);

                    // Check the probability, is it percent or decimal?
                    if (model.Probability.HasValue && model.Probability.Value > 1)
                    {
                        model.Probability = model.Probability.Value / 100;
                    }

                    model = Data.Opportunities.Opportunity.Edit(trans, model, currentUser);

                    // Add new contacts
                    viewModel.Contacts.ForEach(x =>
                    {
                        if (x.Id.HasValue)
                        {
                            Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                            {
                                Contact     = Mapper.Map <Common.Models.Contacts.Contact>(x),
                                Opportunity = model
                            };
                            oc = Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                        }
                    });

                    // Handle deletions
                    Data.Opportunities.OpportunityContact.ListForOpportunity(trans, model.Id.Value).ForEach(x =>
                    {
                        if (!viewModel.Contacts.Any(vm =>
                        {
                            if (vm.Id.HasValue)
                            {
                                return(vm.Id.Value == x.Contact.Id.Value);
                            }
                            return(false);
                        }))
                        {
                            Data.Opportunities.OpportunityContact.Disable(trans, x, currentUser);
                        }
                    });

                    trans.Commit();

                    return(RedirectToAction("Details", new { Id = id }));
                }
                catch (Exception ex)
                {
                    trans.Rollback();
                    return(Edit(id));
                }
            }
        }
        public ActionResult Convert(long id, ViewModels.Leads.LeadConvertViewModel viewModel)
        {
            Common.Models.Account.Users             currentUser;
            Common.Models.Opportunities.Opportunity model;

            using (Data.Transaction trans = Data.Transaction.Create(true))
            {
                try
                {
                    currentUser = Data.Account.Users.Get(trans, User.Identity.Name);
                    Common.Models.Leads.Lead oldLead = Data.Leads.Lead.Get(trans, id);

                    model      = Mapper.Map <Common.Models.Opportunities.Opportunity>(viewModel.Opportunity);
                    model.Lead = Mapper.Map <Common.Models.Leads.Lead>(viewModel.Opportunity.Lead);
                    //model.Lead.Source = Mapper.Map<Common.Models.Leads.LeadSource>(viewModel.Lead.Source);
                    model.Lead.Fee = Mapper.Map <Common.Models.Leads.LeadFee>(viewModel.Opportunity.Lead.Fee);


                    if (oldLead.Fee != null)
                    {
                        model.Lead.Fee = Data.Leads.LeadFee.Edit(trans, model.Lead.Fee, currentUser);
                    }
                    else
                    {
                        model.Lead.Fee = Data.Leads.LeadFee.Create(trans, model.Lead.Fee, currentUser);
                    }

                    //model.Lead.Source = Data.Leads.LeadSource.Edit(trans, model.Lead.Source, currentUser);
                    model.Lead = Data.Leads.Lead.Edit(trans, model.Lead, currentUser);

                    // Check the probability, is it percent or decimal?
                    if (model.Probability.HasValue && model.Probability.Value > 1)
                    {
                        model.Probability = model.Probability.Value / 100;
                    }

                    model = Data.Opportunities.Opportunity.Create(trans, model, currentUser);

                    // Contacts involved
                    if (viewModel.Contact1 != null & viewModel.Contact1.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact1)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact2 != null & viewModel.Contact2.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact2)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact3 != null & viewModel.Contact3.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact3)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact4 != null & viewModel.Contact4.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact4)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact5 != null & viewModel.Contact5.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact5)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact6 != null & viewModel.Contact6.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact6)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact7 != null & viewModel.Contact7.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact7)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact8 != null & viewModel.Contact8.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact8)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact9 != null & viewModel.Contact9.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact9)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }
                    if (viewModel.Contact10 != null & viewModel.Contact10.Id.HasValue)
                    {
                        Common.Models.Opportunities.OpportunityContact oc = new Common.Models.Opportunities.OpportunityContact()
                        {
                            Opportunity = new Common.Models.Opportunities.Opportunity()
                            {
                                Id = model.Id.Value
                            },
                            Contact = Mapper.Map <Common.Models.Contacts.Contact>(viewModel.Contact10)
                        };
                        Data.Opportunities.OpportunityContact.Create(trans, oc, currentUser);
                    }

                    trans.Commit();

                    return(RedirectToAction("Details", "Opportunities", new { Id = model.Id }));
                }
                catch (Exception ex)
                {
                    trans.Rollback();
                    return(Edit(id));
                }
            }
        }