Merge branch 'master' of http://195.88.208.142:3000/mmr/_Hushian
This commit is contained in:
		| @@ -285,20 +285,25 @@ namespace Hushian.Application.Services | |||||||
|                         await WriteInHubFromCompany(Response.Value, convModel.UserID.ToString()); |                         await WriteInHubFromCompany(Response.Value, convModel.UserID.ToString()); | ||||||
|                     else |                     else | ||||||
|                     { |                     { | ||||||
|  |                         List<string> users = new(); | ||||||
|  |                         users.Add("C" + convModel.CompanyID.ToString()); | ||||||
|  |  | ||||||
|                         var modelA = convModel.ConversationResponses.OrderBy(o => o.ID) |                         var modelA = convModel.ConversationResponses.OrderBy(o => o.ID) | ||||||
|                             .LastOrDefault(l =>/* l.Type == ConversationType.EU || l.Type == ConversationType.CU*/ l.ExperID.HasValue); |                             .LastOrDefault(l =>/* l.Type == ConversationType.EU || l.Type == ConversationType.CU*/ l.ExperID.HasValue); | ||||||
|                         if (modelA != null) |                         if (modelA != null /*&& (modelA.Type == ConversationType.EU || modelA.Type == ConversationType.UE)*/) | ||||||
|                         { |                        // { | ||||||
|                             string user =""; |  | ||||||
|                            |                            | ||||||
|                             if (modelA.Type == ConversationType.EU || modelA.Type == ConversationType.UE) user = modelA.ExperID.Value.ToString(); |  | ||||||
|  |  | ||||||
|                             else if (modelA.Type == ConversationType.CU) user ="C"+ modelA.conversation.CompanyID.ToString(); |                             //if ()  | ||||||
|  |                                 users.Add(modelA.ExperID.Value.ToString()); | ||||||
|  |  | ||||||
|                             await WriteInHubFromUser(Response.Value, user); |  | ||||||
|                             |                             | ||||||
|                         } |  | ||||||
|                        else await NewChatInHub(convModel.CompanyID); |                         | ||||||
|  |  | ||||||
|  |                        // } | ||||||
|  |                         //else await NewChatInHub(convModel.CompanyID); | ||||||
|  |                         await WriteInHubFromUser(Response.Value, users); | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                 } |                 } | ||||||
| @@ -502,8 +507,9 @@ namespace Hushian.Application.Services | |||||||
|             //    //    .SendAsync("ReceiveNewConversation", conv.Id, conv.Title); |             //    //    .SendAsync("ReceiveNewConversation", conv.Id, conv.Title); | ||||||
|             //} |             //} | ||||||
|         } |         } | ||||||
|         public async Task WriteInHubFromUser(ChatItemResponseDto item, string ToUser) |         public async Task WriteInHubFromUser(ChatItemResponseDto item,List< string> ToUserS) | ||||||
|         { |         { | ||||||
|  |             foreach (var ToUser in ToUserS) | ||||||
|             await _hubContext.Clients.User(ToUser) |             await _hubContext.Clients.User(ToUser) | ||||||
|                 .SendAsync("ReceiveNewChatItemFromUser", item); |                 .SendAsync("ReceiveNewChatItemFromUser", item); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -15,6 +15,8 @@ | |||||||
| @inject ILocalStorageService localStorageService; | @inject ILocalStorageService localStorageService; | ||||||
| @inject HttpClient _Http; | @inject HttpClient _Http; | ||||||
| @inject NavigationManager nav | @inject NavigationManager nav | ||||||
|  | @implements IAsyncDisposable | ||||||
|  |  | ||||||
| <ConfirmDialog @ref="dialog" /> | <ConfirmDialog @ref="dialog" /> | ||||||
| <Modal @ref="modal" IsVerticallyCentered="true" IsScrollable="true" /> | <Modal @ref="modal" IsVerticallyCentered="true" IsScrollable="true" /> | ||||||
| <PageTitle>گفتمان</PageTitle> | <PageTitle>گفتمان</PageTitle> | ||||||
| @@ -166,9 +168,11 @@ | |||||||
|  |  | ||||||
|         <!-- Main Chat Section (B) --> |         <!-- Main Chat Section (B) --> | ||||||
|         <div class="col-md-9 d-flex flex-column" id="B"> |         <div class="col-md-9 d-flex flex-column" id="B"> | ||||||
|  |  | ||||||
|             <div class="input-group"> |             <div class="input-group"> | ||||||
|                 @if (ChatCurrent != null) |                 @if (ChatCurrent != null) | ||||||
|                 { |                 { | ||||||
|  |                     <small>@ChatCurrent?.ID)</small> | ||||||
|                     <p type="text" class="form-control fw-bold text-primary" style="border:none;align-self: center;" aria-describedby="basic-addon1">@SelectedChatUserName</p> |                     <p type="text" class="form-control fw-bold text-primary" style="border:none;align-self: center;" aria-describedby="basic-addon1">@SelectedChatUserName</p> | ||||||
|                     <div class="d-flex gap-2 ms-auto"> |                     <div class="d-flex gap-2 ms-auto"> | ||||||
|                         @if (ChatCurrent.status == Common.Enums.ConversationStatus.InProgress) |                         @if (ChatCurrent.status == Common.Enums.ConversationStatus.InProgress) | ||||||
| @@ -400,7 +404,7 @@ | |||||||
|     private DateTime recordingStartTime; |     private DateTime recordingStartTime; | ||||||
|  |  | ||||||
|     bool chatloading = false; |     bool chatloading = false; | ||||||
|     string SelectedChatUserName = "مهدی ربیع نژاد"; |     string SelectedChatUserName = ""; | ||||||
|     private bool _shouldObserveVisibility = false; |     private bool _shouldObserveVisibility = false; | ||||||
|     private ConfirmDialog dialog = default!; |     private ConfirmDialog dialog = default!; | ||||||
|     private Modal modal = default!; |     private Modal modal = default!; | ||||||
| @@ -555,7 +559,21 @@ | |||||||
|     { |     { | ||||||
|  |  | ||||||
|         chatloading = true; |         chatloading = true; | ||||||
|         SelectedChatUserName = "در حال گفتگو با " + chatItem.UserFullName; |  | ||||||
|  |         SelectedChatUserName = "در حال گفتگو با '" + chatItem.UserFullName + "'"; | ||||||
|  |         | ||||||
|  |         if (CurrentUser.Role == "Company") | ||||||
|  |         { | ||||||
|  |             var mo = chatItem.Responses.OrderBy(o => o.ID).Last(l => l.Type != ConversationType.UE); | ||||||
|  |             if (mo!=null && mo.Type == Common.Enums.ConversationType.EU) | ||||||
|  |             SelectedChatUserName = "گفتگوی '" + mo.ExperName + "' با '" + chatItem.UserFullName+"'"; | ||||||
|  |  | ||||||
|  |              | ||||||
|  |         } | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|         ChatCurrent = chatItem; |         ChatCurrent = chatItem; | ||||||
|  |  | ||||||
|         _shouldObserveVisibility = true; // فعال کن تا در OnAfterRenderAsync صدا زده بشه |         _shouldObserveVisibility = true; // فعال کن تا در OnAfterRenderAsync صدا زده بشه | ||||||
| @@ -766,7 +784,14 @@ | |||||||
|         SelectedImagePreview = null; |         SelectedImagePreview = null; | ||||||
|         return Task.CompletedTask; |         return Task.CompletedTask; | ||||||
|     } |     } | ||||||
|     |     public async ValueTask DisposeAsync() | ||||||
|  |     { | ||||||
|  |         if (hubConnection is not null) | ||||||
|  |         { | ||||||
|  |             await hubConnection.StopAsync(); | ||||||
|  |             await hubConnection.DisposeAsync(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| <style> | <style> | ||||||
|   | |||||||
| @@ -7,10 +7,13 @@ | |||||||
| @using HushianWebApp.Services | @using HushianWebApp.Services | ||||||
| @using Microsoft.AspNetCore.SignalR.Client; | @using Microsoft.AspNetCore.SignalR.Client; | ||||||
| @using System.Threading; | @using System.Threading; | ||||||
| @if(CompanyInfo!=null) | <PageTitle>به هوشیان خوش آمدید</PageTitle> | ||||||
|  |  | ||||||
|  | @if (CompanyInfo != null && !string.IsNullOrEmpty(CompanyInfo?.FullName)) | ||||||
| { | { | ||||||
|     <PageTitle>گفتگو با @CompanyInfo?.FullName</PageTitle> |     <PageTitle>گفتگو با @CompanyInfo?.FullName</PageTitle> | ||||||
| } | } | ||||||
|  | @implements IAsyncDisposable | ||||||
| @inject NavigationManager NavigationManager | @inject NavigationManager NavigationManager | ||||||
| @inject ChatService ChatService | @inject ChatService ChatService | ||||||
| @inject ILocalStorageService localStorageService; | @inject ILocalStorageService localStorageService; | ||||||
| @@ -240,7 +243,10 @@ | |||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|  |                     @if (LastOpenChat.status == Common.Enums.ConversationStatus.Finished) | ||||||
|  |                     { | ||||||
|  |                         <p style="color: red;text-align: center;font-weight: bold;">این گفتگو به پایان رسیده</p> | ||||||
|  |                     } | ||||||
|                 </div> |                 </div> | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
| @@ -721,6 +727,14 @@ | |||||||
|         } |         } | ||||||
|         return $"image_{DateTimeOffset.Now.ToUnixTimeSeconds()}{ext}"; |         return $"image_{DateTimeOffset.Now.ToUnixTimeSeconds()}{ext}"; | ||||||
|     } |     } | ||||||
|  |     public async ValueTask DisposeAsync() | ||||||
|  |     { | ||||||
|  |         if (hubConnection is not null) | ||||||
|  |         { | ||||||
|  |             await hubConnection.StopAsync(); | ||||||
|  |             await hubConnection.DisposeAsync(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
| <style> | <style> | ||||||
|     .chat-bubble { |     .chat-bubble { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 mmrbnjd
					mmrbnjd