Revert "added an API to get list of contacts by bucket id and added project- contact mapping table"
This reverts commit 22f777ca87053d2c79db610a27b8d7a5169e57bc.
This commit is contained in:
		
							parent
							
								
									4cebaba540
								
							
						
					
					
						commit
						244a6cc547
					
				| @ -78,7 +78,6 @@ namespace Marco.Pms.DataAccess.Data | |||||||
|         public DbSet<ContactTagMapping> ContactTagMappings { get; set; } |         public DbSet<ContactTagMapping> ContactTagMappings { get; set; } | ||||||
|         public DbSet<EmployeeBucketMapping> EmployeeBucketMappings { get; set; } |         public DbSet<EmployeeBucketMapping> EmployeeBucketMappings { get; set; } | ||||||
|         public DbSet<ContactBucketMapping> ContactBucketMappings { get; set; } |         public DbSet<ContactBucketMapping> ContactBucketMappings { get; set; } | ||||||
|         public DbSet<ContactProjectMapping> ContactProjectMappings { get; set; } |  | ||||||
|         public DbSet<DirectoryUpdateLog> DirectoryUpdateLogs { get; set; } |         public DbSet<DirectoryUpdateLog> DirectoryUpdateLogs { get; set; } | ||||||
|         public DbSet<ContactProjectMapping> ContactProjectMappings { get; set; } |         public DbSet<ContactProjectMapping> ContactProjectMappings { get; set; } | ||||||
| 
 | 
 | ||||||
|  | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,81 +0,0 @@ | |||||||
| using System; |  | ||||||
| using Microsoft.EntityFrameworkCore.Migrations; |  | ||||||
| 
 |  | ||||||
| #nullable disable |  | ||||||
| 
 |  | ||||||
| namespace Marco.Pms.DataAccess.Migrations |  | ||||||
| { |  | ||||||
|     /// <inheritdoc /> |  | ||||||
|     public partial class Added_ContactProjectMapping_Table : Migration |  | ||||||
|     { |  | ||||||
|         /// <inheritdoc /> |  | ||||||
|         protected override void Up(MigrationBuilder migrationBuilder) |  | ||||||
|         { |  | ||||||
|             migrationBuilder.DropColumn( |  | ||||||
|                 name: "ProjectId", |  | ||||||
|                 table: "Contacts"); |  | ||||||
| 
 |  | ||||||
|             migrationBuilder.CreateTable( |  | ||||||
|                 name: "ContactProjectMappings", |  | ||||||
|                 columns: table => new |  | ||||||
|                 { |  | ||||||
|                     Id = table.Column<Guid>(type: "char(36)", nullable: false, collation: "ascii_general_ci"), |  | ||||||
|                     ProjectId = table.Column<Guid>(type: "char(36)", nullable: false, collation: "ascii_general_ci"), |  | ||||||
|                     ContactId = table.Column<Guid>(type: "char(36)", nullable: false, collation: "ascii_general_ci"), |  | ||||||
|                     TenantId = table.Column<Guid>(type: "char(36)", nullable: false, collation: "ascii_general_ci") |  | ||||||
|                 }, |  | ||||||
|                 constraints: table => |  | ||||||
|                 { |  | ||||||
|                     table.PrimaryKey("PK_ContactProjectMappings", x => x.Id); |  | ||||||
|                     table.ForeignKey( |  | ||||||
|                         name: "FK_ContactProjectMappings_Contacts_ContactId", |  | ||||||
|                         column: x => x.ContactId, |  | ||||||
|                         principalTable: "Contacts", |  | ||||||
|                         principalColumn: "Id", |  | ||||||
|                         onDelete: ReferentialAction.Cascade); |  | ||||||
|                     table.ForeignKey( |  | ||||||
|                         name: "FK_ContactProjectMappings_Projects_ProjectId", |  | ||||||
|                         column: x => x.ProjectId, |  | ||||||
|                         principalTable: "Projects", |  | ||||||
|                         principalColumn: "Id", |  | ||||||
|                         onDelete: ReferentialAction.Cascade); |  | ||||||
|                     table.ForeignKey( |  | ||||||
|                         name: "FK_ContactProjectMappings_Tenants_TenantId", |  | ||||||
|                         column: x => x.TenantId, |  | ||||||
|                         principalTable: "Tenants", |  | ||||||
|                         principalColumn: "Id", |  | ||||||
|                         onDelete: ReferentialAction.Cascade); |  | ||||||
|                 }) |  | ||||||
|                 .Annotation("MySql:CharSet", "utf8mb4"); |  | ||||||
| 
 |  | ||||||
|             migrationBuilder.CreateIndex( |  | ||||||
|                 name: "IX_ContactProjectMappings_ContactId", |  | ||||||
|                 table: "ContactProjectMappings", |  | ||||||
|                 column: "ContactId"); |  | ||||||
| 
 |  | ||||||
|             migrationBuilder.CreateIndex( |  | ||||||
|                 name: "IX_ContactProjectMappings_ProjectId", |  | ||||||
|                 table: "ContactProjectMappings", |  | ||||||
|                 column: "ProjectId"); |  | ||||||
| 
 |  | ||||||
|             migrationBuilder.CreateIndex( |  | ||||||
|                 name: "IX_ContactProjectMappings_TenantId", |  | ||||||
|                 table: "ContactProjectMappings", |  | ||||||
|                 column: "TenantId"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <inheritdoc /> |  | ||||||
|         protected override void Down(MigrationBuilder migrationBuilder) |  | ||||||
|         { |  | ||||||
|             migrationBuilder.DropTable( |  | ||||||
|                 name: "ContactProjectMappings"); |  | ||||||
| 
 |  | ||||||
|             migrationBuilder.AddColumn<Guid>( |  | ||||||
|                 name: "ProjectId", |  | ||||||
|                 table: "Contacts", |  | ||||||
|                 type: "char(36)", |  | ||||||
|                 nullable: true, |  | ||||||
|                 collation: "ascii_general_ci"); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -328,6 +328,9 @@ namespace Marco.Pms.DataAccess.Migrations | |||||||
|                         .IsRequired() |                         .IsRequired() | ||||||
|                         .HasColumnType("longtext"); |                         .HasColumnType("longtext"); | ||||||
| 
 | 
 | ||||||
|  |                     b.Property<Guid?>("ProjectId") | ||||||
|  |                         .HasColumnType("char(36)"); | ||||||
|  | 
 | ||||||
|                     b.Property<Guid>("TenantId") |                     b.Property<Guid>("TenantId") | ||||||
|                         .HasColumnType("char(36)"); |                         .HasColumnType("char(36)"); | ||||||
| 
 | 
 | ||||||
| @ -483,32 +486,6 @@ namespace Marco.Pms.DataAccess.Migrations | |||||||
|                     b.ToTable("ContactsPhones"); |                     b.ToTable("ContactsPhones"); | ||||||
|                 }); |                 }); | ||||||
| 
 | 
 | ||||||
|             modelBuilder.Entity("Marco.Pms.Model.Directory.ContactProjectMapping", b => |  | ||||||
|                 { |  | ||||||
|                     b.Property<Guid>("Id") |  | ||||||
|                         .ValueGeneratedOnAdd() |  | ||||||
|                         .HasColumnType("char(36)"); |  | ||||||
| 
 |  | ||||||
|                     b.Property<Guid>("ContactId") |  | ||||||
|                         .HasColumnType("char(36)"); |  | ||||||
| 
 |  | ||||||
|                     b.Property<Guid>("ProjectId") |  | ||||||
|                         .HasColumnType("char(36)"); |  | ||||||
| 
 |  | ||||||
|                     b.Property<Guid>("TenantId") |  | ||||||
|                         .HasColumnType("char(36)"); |  | ||||||
| 
 |  | ||||||
|                     b.HasKey("Id"); |  | ||||||
| 
 |  | ||||||
|                     b.HasIndex("ContactId"); |  | ||||||
| 
 |  | ||||||
|                     b.HasIndex("ProjectId"); |  | ||||||
| 
 |  | ||||||
|                     b.HasIndex("TenantId"); |  | ||||||
| 
 |  | ||||||
|                     b.ToTable("ContactProjectMappings"); |  | ||||||
|                 }); |  | ||||||
| 
 |  | ||||||
|             modelBuilder.Entity("Marco.Pms.Model.Directory.ContactTagMapping", b => |             modelBuilder.Entity("Marco.Pms.Model.Directory.ContactTagMapping", b => | ||||||
|                 { |                 { | ||||||
|                     b.Property<Guid>("Id") |                     b.Property<Guid>("Id") | ||||||
| @ -2609,33 +2586,6 @@ namespace Marco.Pms.DataAccess.Migrations | |||||||
|                     b.Navigation("Contact"); |                     b.Navigation("Contact"); | ||||||
|                 }); |                 }); | ||||||
| 
 | 
 | ||||||
|             modelBuilder.Entity("Marco.Pms.Model.Directory.ContactProjectMapping", b => |  | ||||||
|                 { |  | ||||||
|                     b.HasOne("Marco.Pms.Model.Directory.Contact", "Contact") |  | ||||||
|                         .WithMany() |  | ||||||
|                         .HasForeignKey("ContactId") |  | ||||||
|                         .OnDelete(DeleteBehavior.Cascade) |  | ||||||
|                         .IsRequired(); |  | ||||||
| 
 |  | ||||||
|                     b.HasOne("Marco.Pms.Model.Projects.Project", "Project") |  | ||||||
|                         .WithMany() |  | ||||||
|                         .HasForeignKey("ProjectId") |  | ||||||
|                         .OnDelete(DeleteBehavior.Cascade) |  | ||||||
|                         .IsRequired(); |  | ||||||
| 
 |  | ||||||
|                     b.HasOne("Marco.Pms.Model.Entitlements.Tenant", "Tenant") |  | ||||||
|                         .WithMany() |  | ||||||
|                         .HasForeignKey("TenantId") |  | ||||||
|                         .OnDelete(DeleteBehavior.Cascade) |  | ||||||
|                         .IsRequired(); |  | ||||||
| 
 |  | ||||||
|                     b.Navigation("Contact"); |  | ||||||
| 
 |  | ||||||
|                     b.Navigation("Project"); |  | ||||||
| 
 |  | ||||||
|                     b.Navigation("Tenant"); |  | ||||||
|                 }); |  | ||||||
| 
 |  | ||||||
|             modelBuilder.Entity("Marco.Pms.Model.Directory.ContactTagMapping", b => |             modelBuilder.Entity("Marco.Pms.Model.Directory.ContactTagMapping", b => | ||||||
|                 { |                 { | ||||||
|                     b.HasOne("Marco.Pms.Model.Directory.Contact", "Contact") |                     b.HasOne("Marco.Pms.Model.Directory.Contact", "Contact") | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ namespace Marco.Pms.Model.Directory | |||||||
|     public class Contact : TenantRelation |     public class Contact : TenantRelation | ||||||
|     { |     { | ||||||
|         public Guid Id { get; set; } |         public Guid Id { get; set; } | ||||||
|         //public Guid? ProjectId { get; set; } |         public Guid? ProjectId { get; set; } | ||||||
|         public string Name { get; set; } = string.Empty; |         public string Name { get; set; } = string.Empty; | ||||||
|         public string Description { get; set; } = string.Empty; |         public string Description { get; set; } = string.Empty; | ||||||
|         public string Organization { get; set; } = string.Empty; |         public string Organization { get; set; } = string.Empty; | ||||||
|  | |||||||
| @ -1,20 +0,0 @@ | |||||||
| using System.ComponentModel.DataAnnotations.Schema; |  | ||||||
| using Marco.Pms.Model.Projects; |  | ||||||
| using Marco.Pms.Model.Utilities; |  | ||||||
| using Microsoft.AspNetCore.Mvc.ModelBinding.Validation; |  | ||||||
| 
 |  | ||||||
| namespace Marco.Pms.Model.Directory |  | ||||||
| { |  | ||||||
|     public class ContactProjectMapping : TenantRelation |  | ||||||
|     { |  | ||||||
|         public Guid Id { get; set; } |  | ||||||
|         public Guid ProjectId { get; set; } |  | ||||||
|         [ValidateNever] |  | ||||||
|         [ForeignKey("ProjectId")] |  | ||||||
|         public Project? Project { get; set; } |  | ||||||
|         public Guid ContactId { get; set; } |  | ||||||
|         [ValidateNever] |  | ||||||
|         [ForeignKey("ContactId")] |  | ||||||
|         public Contact? Contact { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -2,7 +2,7 @@ | |||||||
| { | { | ||||||
|     public class CreateContactDto |     public class CreateContactDto | ||||||
|     { |     { | ||||||
|         public List<Guid>? ProjectIds { get; set; } |         public Guid? ProjectId { get; set; } | ||||||
|         public string? Name { get; set; } |         public string? Name { get; set; } | ||||||
|         public List<CreateContactPhoneDto>? ContactPhones { get; set; } |         public List<CreateContactPhoneDto>? ContactPhones { get; set; } | ||||||
|         public List<CreateContactEmailDto>? ContactEmails { get; set; } |         public List<CreateContactEmailDto>? ContactEmails { get; set; } | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
|     public class UpdateContactDto |     public class UpdateContactDto | ||||||
|     { |     { | ||||||
|         public Guid Id { get; set; } |         public Guid Id { get; set; } | ||||||
|         public List<Guid>? ProjectIds { get; set; } |         public Guid? ProjectId { get; set; } | ||||||
|         public string? Name { get; set; } |         public string? Name { get; set; } | ||||||
|         public List<UpdateContactPhoneDto>? ContactPhones { get; set; } |         public List<UpdateContactPhoneDto>? ContactPhones { get; set; } | ||||||
|         public List<UpdateContactEmailDto>? ContactEmails { get; set; } |         public List<UpdateContactEmailDto>? ContactEmails { get; set; } | ||||||
|  | |||||||
| @ -13,6 +13,7 @@ namespace Marco.Pms.Model.Mapper | |||||||
| 
 | 
 | ||||||
|             return new Contact |             return new Contact | ||||||
|             { |             { | ||||||
|  |                 ProjectId = createContactDto.ProjectId, | ||||||
|                 Name = createContactDto.Name ?? string.Empty, |                 Name = createContactDto.Name ?? string.Empty, | ||||||
|                 ContactCategoryId = createContactDto.ContactCategoryId, |                 ContactCategoryId = createContactDto.ContactCategoryId, | ||||||
|                 Description = createContactDto.Description ?? string.Empty, |                 Description = createContactDto.Description ?? string.Empty, | ||||||
| @ -29,6 +30,7 @@ namespace Marco.Pms.Model.Mapper | |||||||
|             return new Contact |             return new Contact | ||||||
|             { |             { | ||||||
|                 Id = updateContactDto.Id, |                 Id = updateContactDto.Id, | ||||||
|  |                 ProjectId = updateContactDto.ProjectId, | ||||||
|                 Name = updateContactDto.Name ?? string.Empty, |                 Name = updateContactDto.Name ?? string.Empty, | ||||||
|                 ContactCategoryId = updateContactDto.ContactCategoryId, |                 ContactCategoryId = updateContactDto.ContactCategoryId, | ||||||
|                 CreatedAt = contact.CreatedAt, |                 CreatedAt = contact.CreatedAt, | ||||||
| @ -44,6 +46,7 @@ namespace Marco.Pms.Model.Mapper | |||||||
|             return new ContactVM |             return new ContactVM | ||||||
|             { |             { | ||||||
|                 Id = contact.Id, |                 Id = contact.Id, | ||||||
|  |                 ProjectId = contact.ProjectId, | ||||||
|                 Name = contact.Name, |                 Name = contact.Name, | ||||||
|                 ContactCategory = contact.ContactCategory != null ? contact.ContactCategory.ToContactCategoryVMFromContactCategoryMaster() : null, |                 ContactCategory = contact.ContactCategory != null ? contact.ContactCategory.ToContactCategoryVMFromContactCategoryMaster() : null, | ||||||
|                 Description = contact.Description ?? string.Empty, |                 Description = contact.Description ?? string.Empty, | ||||||
|  | |||||||
| @ -5,12 +5,11 @@ namespace Marco.Pms.Model.ViewModels.Directory | |||||||
|     public class ContactVM |     public class ContactVM | ||||||
|     { |     { | ||||||
|         public Guid Id { get; set; } |         public Guid Id { get; set; } | ||||||
|         public List<Guid>? ProjectIds { get; set; } |         public Guid? ProjectId { get; set; } | ||||||
|         public string? Name { get; set; } |         public string? Name { get; set; } | ||||||
|         public List<ContactPhoneVM>? ContactPhones { get; set; } |         public List<ContactPhoneVM>? ContactPhones { get; set; } | ||||||
|         public List<ContactEmailVM>? ContactEmails { get; set; } |         public List<ContactEmailVM>? ContactEmails { get; set; } | ||||||
|         public ContactCategoryVM? ContactCategory { get; set; } |         public ContactCategoryVM? ContactCategory { get; set; } | ||||||
|         public List<Guid>? BucketIds { get; set; } |  | ||||||
|         public string? Description { get; set; } |         public string? Description { get; set; } | ||||||
|         public string? Organization { get; set; } |         public string? Organization { get; set; } | ||||||
|         public string? Address { get; set; } |         public string? Address { get; set; } | ||||||
|  | |||||||
| @ -63,24 +63,6 @@ namespace Marco.Pms.Services.Controllers | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         [HttpGet("contact-bucket/{bucketId}")] |  | ||||||
|         public async Task<IActionResult> GetContactsListByBucketId(Guid bucketId) |  | ||||||
|         { |  | ||||||
|             var response = await _directoryHelper.GetContactsListByBucketId(bucketId); |  | ||||||
|             if (response.StatusCode == 200) |  | ||||||
|             { |  | ||||||
|                 return Ok(response); |  | ||||||
|             } |  | ||||||
|             else if (response.StatusCode == 401) |  | ||||||
|             { |  | ||||||
|                 return Unauthorized(response); |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 return BadRequest(response); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         [HttpPost] |         [HttpPost] | ||||||
|         public async Task<IActionResult> CreateContact([FromBody] CreateContactDto createContact) |         public async Task<IActionResult> CreateContact([FromBody] CreateContactDto createContact) | ||||||
|         { |         { | ||||||
|  | |||||||
| @ -97,8 +97,6 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                 var phones = phoneNo.Where(p => p.ContactId == contact.Id).ToList(); |                 var phones = phoneNo.Where(p => p.ContactId == contact.Id).ToList(); | ||||||
|                 var emails = Emails.Where(e => e.ContactId == contact.Id).ToList(); |                 var emails = Emails.Where(e => e.ContactId == contact.Id).ToList(); | ||||||
|                 var tagMappingss = Tags.Where(t => t.ContactId == contact.Id).ToList(); |                 var tagMappingss = Tags.Where(t => t.ContactId == contact.Id).ToList(); | ||||||
|                 var projectMapping = contactProjects.Where(p => p.ContactId == contact.Id).ToList(); |  | ||||||
|                 var bucketMapping = contactBuckets.Where(b => b.ContactId == contact.Id).ToList(); |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|                 if (emails != null && emails.Count > 0) |                 if (emails != null && emails.Count > 0) | ||||||
| @ -111,7 +109,7 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 if (phones != null && phones.Count > 0) |                 if (phones != null) | ||||||
|                 { |                 { | ||||||
|                     foreach (var phone in phones) |                     foreach (var phone in phones) | ||||||
|                     { |                     { | ||||||
| @ -121,7 +119,7 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|                 } |                 } | ||||||
|                 if (tagMappingss != null && tagMappingss.Count > 0) |                 if (tagMappingss != null) | ||||||
|                 { |                 { | ||||||
|                     foreach (var tagMapping in tagMappingss) |                     foreach (var tagMapping in tagMappingss) | ||||||
|                     { |                     { | ||||||
| @ -134,17 +132,9 @@ namespace Marco.Pms.Services.Helpers | |||||||
| 
 | 
 | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|                 contactVM = contact.ToContactVMFromContact(); |                 contactVM = contact.ToContactVMFromContact(); | ||||||
| 
 |  | ||||||
|                 if (projectMapping != null && projectMapping.Count > 0) |  | ||||||
|                 { |  | ||||||
|                     contactVM.ProjectIds = projectMapping.Select(p => p.ProjectId).ToList(); |  | ||||||
|                 } |  | ||||||
|                 if (bucketMapping != null && bucketMapping.Count > 0) |  | ||||||
|                 { |  | ||||||
|                     contactVM.BucketIds = bucketMapping.Select(p => p.BucketId).ToList(); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 contactVM.ContactEmails = contactEmailVms; |                 contactVM.ContactEmails = contactEmailVms; | ||||||
|                 contactVM.ContactPhones = contactPhoneVms; |                 contactVM.ContactPhones = contactPhoneVms; | ||||||
|                 contactVM.Tags = conatctTagVms; |                 contactVM.Tags = conatctTagVms; | ||||||
| @ -270,8 +260,6 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                 var tags = await _context.ContactTagMasters.Where(t => t.TenantId == tenantId).ToListAsync(); |                 var tags = await _context.ContactTagMasters.Where(t => t.TenantId == tenantId).ToListAsync(); | ||||||
|                 var tagNames = tags.Select(t => t.Name.ToLower()).ToList(); |                 var tagNames = tags.Select(t => t.Name.ToLower()).ToList(); | ||||||
|                 var buckets = await _context.Buckets.Where(b => b.TenantId == tenantId).Select(b => b.Id).ToListAsync(); |                 var buckets = await _context.Buckets.Where(b => b.TenantId == tenantId).Select(b => b.Id).ToListAsync(); | ||||||
|                 var projects = await _context.Projects.Where(p => p.TenantId == tenantId).Select(p => p.Id).ToListAsync(); |  | ||||||
| 
 |  | ||||||
|                 if (createContact.ContactPhones != null) |                 if (createContact.ContactPhones != null) | ||||||
|                 { |                 { | ||||||
| 
 | 
 | ||||||
| @ -294,7 +282,6 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                     _context.ContactsEmails.AddRange(emails); |                     _context.ContactsEmails.AddRange(emails); | ||||||
|                     _logger.LogInfo("{count} email addresses are saved in contact with ID {ContactId} by employee with ID {LoggedEmployeeId}", emails.Count, contact.Id, LoggedInEmployee.Id); |                     _logger.LogInfo("{count} email addresses are saved in contact with ID {ContactId} by employee with ID {LoggedEmployeeId}", emails.Count, contact.Id, LoggedInEmployee.Id); | ||||||
|                 } |                 } | ||||||
| 
 |  | ||||||
|                 if (createContact.BucketIds != null) |                 if (createContact.BucketIds != null) | ||||||
|                 { |                 { | ||||||
|                     foreach (var bucket in createContact.BucketIds) |                     foreach (var bucket in createContact.BucketIds) | ||||||
| @ -310,29 +297,8 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                     _context.ContactBucketMappings.AddRange(contactBucketMappings); |                     _context.ContactBucketMappings.AddRange(contactBucketMappings); | ||||||
|                     _logger.LogInfo("Contact with ID {ContactId} added to {count} number of buckets by employee with ID {LoggedEmployeeId}", contact.Id, contactBucketMappings.Count, LoggedInEmployee.Id); |                     _logger.LogInfo("Contact with ID {ContactId} added to {count} number of buckets by employee with ID {LoggedEmployeeId}", contact.Id, LoggedInEmployee.Id); | ||||||
|                 } |                 } | ||||||
| 
 |  | ||||||
|                 if (createContact.ProjectIds != null) |  | ||||||
|                 { |  | ||||||
|                     List<ContactProjectMapping> projectMappings = new List<ContactProjectMapping>(); |  | ||||||
|                     foreach (var projectId in createContact.ProjectIds) |  | ||||||
|                     { |  | ||||||
|                         if (projects.Contains(projectId)) |  | ||||||
|                         { |  | ||||||
|                             ContactProjectMapping projectMapping = new ContactProjectMapping |  | ||||||
|                             { |  | ||||||
|                                 ProjectId = projectId, |  | ||||||
|                                 ContactId = contact.Id, |  | ||||||
|                                 TenantId = tenantId |  | ||||||
|                             }; |  | ||||||
|                             projectMappings.Add(projectMapping); |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                     _context.ContactProjectMappings.AddRange(projectMappings); |  | ||||||
|                     _logger.LogInfo("Contact with ID {ContactId} added to {count} number of project by employee with ID {LoggedEmployeeId}", contact.Id, projectMappings.Count, LoggedInEmployee.Id); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 if (createContact.Tags != null) |                 if (createContact.Tags != null) | ||||||
|                 { |                 { | ||||||
|                     foreach (var tag in createContact.Tags) |                     foreach (var tag in createContact.Tags) | ||||||
| @ -350,8 +316,7 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                         { |                         { | ||||||
|                             var newtag = new ContactTagMaster |                             var newtag = new ContactTagMaster | ||||||
|                             { |                             { | ||||||
|                                 Name = tag.Name, |                                 Name = tag.Name | ||||||
|                                 TenantId = tenantId |  | ||||||
|                             }; |                             }; | ||||||
|                             _context.ContactTagMasters.Add(newtag); |                             _context.ContactTagMasters.Add(newtag); | ||||||
|                             ContactTagMapping tagMapping = new ContactTagMapping |                             ContactTagMapping tagMapping = new ContactTagMapping | ||||||
| @ -362,9 +327,7 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                             contactTagMappings.Add(tagMapping); |                             contactTagMappings.Add(tagMapping); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
| 
 |  | ||||||
|                     _context.ContactTagMappings.AddRange(contactTagMappings); |                     _context.ContactTagMappings.AddRange(contactTagMappings); | ||||||
|                     _logger.LogInfo("{count} number of tags added to Contact with ID {ContactId} by employee with ID {LoggedEmployeeId}", contactTagMappings.Count, contact.Id, LoggedInEmployee.Id); |  | ||||||
|                 } |                 } | ||||||
|                 await _context.SaveChangesAsync(); |                 await _context.SaveChangesAsync(); | ||||||
| 
 | 
 | ||||||
| @ -401,8 +364,6 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                 contactVM.ContactPhones = phoneVMs; |                 contactVM.ContactPhones = phoneVMs; | ||||||
|                 contactVM.ContactEmails = emailVMs; |                 contactVM.ContactEmails = emailVMs; | ||||||
|                 contactVM.Tags = tagVMs; |                 contactVM.Tags = tagVMs; | ||||||
|                 contactVM.ProjectIds = contactProjects.Select(cp => cp.ProjectId).ToList(); |  | ||||||
|                 contactVM.BucketIds = bucketMappings.Select(cb => cb.BucketId).ToList(); |  | ||||||
| 
 | 
 | ||||||
|                 return ApiResponse<object>.SuccessResponse(contactVM, "Contact Created Successfully", 200); |                 return ApiResponse<object>.SuccessResponse(contactVM, "Contact Created Successfully", 200); | ||||||
|             } |             } | ||||||
| @ -588,8 +549,7 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                             ContactTagMaster contactTag = new ContactTagMaster |                             ContactTagMaster contactTag = new ContactTagMaster | ||||||
|                             { |                             { | ||||||
|                                 Name = tag.Name, |                                 Name = tag.Name, | ||||||
|                                 Description = "", |                                 Description = "" | ||||||
|                                 TenantId = tenantId |  | ||||||
|                             }; |                             }; | ||||||
|                             _context.ContactTagMasters.Add(contactTag); |                             _context.ContactTagMasters.Add(contactTag); | ||||||
| 
 | 
 | ||||||
| @ -657,9 +617,6 @@ namespace Marco.Pms.Services.Helpers | |||||||
|                 contactVM.ContactPhones = phoneVMs; |                 contactVM.ContactPhones = phoneVMs; | ||||||
|                 contactVM.ContactEmails = emailVMs; |                 contactVM.ContactEmails = emailVMs; | ||||||
|                 contactVM.Tags = tagVMs; |                 contactVM.Tags = tagVMs; | ||||||
|                 contactVM.BucketIds = contactBuckets.Select(cb => cb.BucketId).ToList(); |  | ||||||
|                 contactVM.ProjectIds = contactProjects.Select(cp => cp.ProjectId).ToList(); |  | ||||||
| 
 |  | ||||||
|                 _logger.LogInfo("Conatct {ContactId} has been updated by employee {EmployeeId}", contact.Id, LoggedInEmployee.Id); |                 _logger.LogInfo("Conatct {ContactId} has been updated by employee {EmployeeId}", contact.Id, LoggedInEmployee.Id); | ||||||
|                 return ApiResponse<object>.SuccessResponse(contactVM, "Contact Updated Successfully", 200); |                 return ApiResponse<object>.SuccessResponse(contactVM, "Contact Updated Successfully", 200); | ||||||
|             } |             } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user