Added chatting
This commit is contained in:
parent
2b8cc84053
commit
f6956dfaa0
|
@ -11,11 +11,22 @@
|
||||||
</NotFound>
|
</NotFound>
|
||||||
</Router>
|
</Router>
|
||||||
|
|
||||||
|
@*<MudThemeProvider @bind-IsDarkMode="@_isDarkMode" Theme="MyCustomTheme" />*@
|
||||||
<MudThemeProvider @bind-IsDarkMode="@_isDarkMode" />
|
<MudThemeProvider @bind-IsDarkMode="@_isDarkMode" />
|
||||||
<MudDialogProvider />
|
<MudDialogProvider />
|
||||||
<MudSnackbarProvider />
|
<MudSnackbarProvider />
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
private MudTheme _theme = new();
|
//public static MudTheme MyCustomTheme = new MudTheme()
|
||||||
|
// {
|
||||||
|
// PaletteDark = new PaletteDark()
|
||||||
|
// {
|
||||||
|
// Dark = Colors.Pink.Lighten3,
|
||||||
|
// Background = Colors.Pink.Lighten1,
|
||||||
|
// AppbarBackground = Colors.Pink.Darken4,
|
||||||
|
// DrawerBackground = Colors.Pink.Darken4,
|
||||||
|
// Surface = Colors.Pink.Lighten2,
|
||||||
|
// }
|
||||||
|
//};
|
||||||
private bool _isDarkMode = true;
|
private bool _isDarkMode = true;
|
||||||
}
|
}
|
|
@ -8,7 +8,7 @@
|
||||||
|
|
||||||
<MudLayout Class="overflow-hidden">
|
<MudLayout Class="overflow-hidden">
|
||||||
<MudAppBar Elevation="1">
|
<MudAppBar Elevation="1">
|
||||||
<MudButton Variant="Variant.Filled" Color="Color.Primary" OnClick="RegisterAccount">Clear cookies</MudButton>
|
<MudButton Variant="Variant.Filled" Color="Color.Primary" Disabled=true>Debug button</MudButton>
|
||||||
<MudSpacer />
|
<MudSpacer />
|
||||||
@if (!isLoggedIn)
|
@if (!isLoggedIn)
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,6 @@
|
||||||
<MudNavMenu>
|
<MudNavMenu>
|
||||||
<MudNavLink Match="NavLinkMatch.All" Href="/Posts" Icon="@Icons.Material.Filled.Image">Posts</MudNavLink>
|
<MudNavLink Match="NavLinkMatch.All" Href="/Posts" Icon="@Icons.Material.Filled.Image">Posts</MudNavLink>
|
||||||
<MudNavLink Match="NavLinkMatch.All" Href="/Chatting" Icon="@Icons.Material.Filled.Chat">Chat</MudNavLink>
|
<MudNavLink Match="NavLinkMatch.All" Href="/Chatting" Icon="@Icons.Material.Filled.Chat">Chat</MudNavLink>
|
||||||
<MudNavLink Match="NavLinkMatch.All" Icon="@Icons.Material.Filled.Group">Community</MudNavLink>
|
|
||||||
</MudNavMenu>
|
</MudNavMenu>
|
||||||
</MudDrawer>
|
</MudDrawer>
|
||||||
|
|
||||||
|
@ -37,7 +36,7 @@
|
||||||
{
|
{
|
||||||
<MudPaper Class="ma-2">
|
<MudPaper Class="ma-2">
|
||||||
<MudStack Spacing="0" Class="justify-center">
|
<MudStack Spacing="0" Class="justify-center">
|
||||||
<MudButton Class="ma-4" Variant="Variant.Outlined" Color="Color.Error" OnClick="Logout">Logout</MudButton>
|
<MudButton Class="ma-4" Variant="Variant.Filled" Color="Color.Error" OnClick="Logout">Logout</MudButton>
|
||||||
</MudStack>
|
</MudStack>
|
||||||
</MudPaper>
|
</MudPaper>
|
||||||
}
|
}
|
||||||
|
@ -45,8 +44,8 @@
|
||||||
{
|
{
|
||||||
<MudPaper Class="ma-2">
|
<MudPaper Class="ma-2">
|
||||||
<MudStack Spacing="0" Class="justify-center">
|
<MudStack Spacing="0" Class="justify-center">
|
||||||
<MudButton Class="ma-4" Variant="Variant.Outlined" Color="Color.Primary" OnClick="ShowLogIn">Sign-in</MudButton>
|
<MudButton Class="ma-4" Variant="Variant.Filled" Color="Color.Primary" OnClick="ShowLogIn">Sign-in</MudButton>
|
||||||
<MudButton Class="ma-4" Variant="Variant.Outlined" Color="Color.Success" OnClick="ShowSignUp">Sign-up</MudButton>
|
<MudButton Class="ma-4" Variant="Variant.Filled" Color="Color.Success" OnClick="ShowSignUp">Sign-up</MudButton>
|
||||||
</MudStack>
|
</MudStack>
|
||||||
</MudPaper>
|
</MudPaper>
|
||||||
}
|
}
|
||||||
|
@ -245,6 +244,7 @@
|
||||||
|
|
||||||
protected override async Task OnInitializedAsync()
|
protected override async Task OnInitializedAsync()
|
||||||
{
|
{
|
||||||
|
StateHasChanged();
|
||||||
CheckLoggedin();
|
CheckLoggedin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -253,10 +253,9 @@
|
||||||
string? name = await localStorage.GetItemAsStringAsync("User");
|
string? name = await localStorage.GetItemAsStringAsync("User");
|
||||||
if (name == null) return;
|
if (name == null) return;
|
||||||
|
|
||||||
Snackbar.Add("Successfully logged in!", Severity.Success);
|
|
||||||
|
|
||||||
Program.LoggedInName = name;
|
Program.LoggedInName = name;
|
||||||
isLoggedIn = true;
|
isLoggedIn = true;
|
||||||
|
Snackbar.Add($"Successfully logged in as: {Program.LoggedInName}.", Severity.Success);
|
||||||
StateHasChanged();
|
StateHasChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,8 @@
|
||||||
@inject NavigationManager NavManager
|
@inject NavigationManager NavManager
|
||||||
@inject HttpClient Http
|
@inject HttpClient Http
|
||||||
@inject IJSRuntime JSRuntime
|
@inject IJSRuntime JSRuntime
|
||||||
|
@inject ISnackbar Snackbar
|
||||||
|
@inject MessageService messageService
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
.bottom-start {
|
.bottom-start {
|
||||||
|
@ -23,7 +25,7 @@
|
||||||
{
|
{
|
||||||
Message message = messages[i];
|
Message message = messages[i];
|
||||||
|
|
||||||
if ("dumb zhen" == message.Name)
|
if (Program.LoggedInName != null && Program.LoggedInName == message.Name)
|
||||||
{
|
{
|
||||||
<MudStack Class="px-4 py-2 d-flex" Justify="Justify.FlexEnd" Row="true" AlignItems="AlignItems.End">
|
<MudStack Class="px-4 py-2 d-flex" Justify="Justify.FlexEnd" Row="true" AlignItems="AlignItems.End">
|
||||||
<MudStack>
|
<MudStack>
|
||||||
|
@ -31,7 +33,7 @@
|
||||||
<MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText>
|
<MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText>
|
||||||
<MudText Class="pa-1 pr-2" Align="Align.End" Style="font-size: 10px;">@("@" + message.Name)</MudText>
|
<MudText Class="pa-1 pr-2" Align="Align.End" Style="font-size: 10px;">@("@" + message.Name)</MudText>
|
||||||
</MudPaper>
|
</MudPaper>
|
||||||
<MudText Class="mt-n3" Align="Align.End" Style="font-size: 10px;">@(DateTime.Now.ToString("dd/MM/yyyy HH:mm", danishCulture))</MudText>
|
<MudText Class="mt-n3" Align="Align.End" Style="font-size: 10px;">@(DateTimeOffset.FromUnixTimeSeconds(message.DatePosted).ToString("dd/MM HH:mm", danishCulture))</MudText>
|
||||||
</MudStack>
|
</MudStack>
|
||||||
</MudStack>
|
</MudStack>
|
||||||
}
|
}
|
||||||
|
@ -43,7 +45,7 @@
|
||||||
<MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText>
|
<MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText>
|
||||||
<MudText Class="pa-1" Style="font-size: 10px;">@("@" + message.Name)</MudText>
|
<MudText Class="pa-1" Style="font-size: 10px;">@("@" + message.Name)</MudText>
|
||||||
</MudPaper>
|
</MudPaper>
|
||||||
<MudText Class="mt-n3 pl-1" Style="font-size: 10px;">@(DateTime.Now.ToString("dd/MM HH:mm", danishCulture))</MudText>
|
<MudText Class="mt-n3 pl-1" Style="font-size: 10px;">@(DateTimeOffset.FromUnixTimeSeconds(message.DatePosted).ToString("dd/MM HH:mm", danishCulture))</MudText>
|
||||||
</MudStack>
|
</MudStack>
|
||||||
</MudStack>
|
</MudStack>
|
||||||
}
|
}
|
||||||
|
@ -51,16 +53,16 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
</MudPaper>
|
</MudPaper>
|
||||||
<MudContainer Class="d-flex pa-0">
|
<MudContainer Class="d-flex pa-0 mb-n1">
|
||||||
<MudTextField Class="my-1" @bind-Value="TextValue" Label="Filled" Variant="Variant.Filled" Margin="Margin.Dense"></MudTextField>
|
<MudTextField Class="my-1" HelperText="Messages cannot be deleted!" HelperTextOnFocus=true Counter="25" @bind-Value="TextValue" MaxLength="32" Immediate="true" Validation="@(new Func<string, IEnumerable<string>>(MaxCharacters))" Disabled="@(Program.LoggedInName == null)" Label="@((Program.LoggedInName == null) ? "Sign-in to send messages" : "Message")" Variant="Variant.Filled" AdornmentColor="@Color.Primary" Margin="Margin.Dense"></MudTextField>
|
||||||
<MudButton Class="my-1" Variant="Variant.Filled" Color="Color.Primary" Disabled="isSending" OnClick="SendMessage">
|
<MudButton Class="mt-1 mb-7" Variant="Variant.Filled" Color="Color.Primary" Disabled="@(Program.LoggedInName == null || isSending)" OnClick="SendMessage">
|
||||||
@if (isSending)
|
@if (isSending)
|
||||||
{
|
{
|
||||||
<MudProgressCircular Class="ms-n1 mr-2" Size="Size.Small" Indeterminate="true" />
|
<MudProgressCircular Class="ms-n1 mr-2" Size="Size.Small" Indeterminate="true" />
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
<MudIcon Icon="@Icons.Material.Rounded.Send" Class="mr-1"/>
|
<MudIcon Icon="@Icons.Material.Rounded.Send" Class="mr-1" />
|
||||||
}
|
}
|
||||||
Send
|
Send
|
||||||
</MudButton>
|
</MudButton>
|
||||||
|
@ -78,17 +80,39 @@
|
||||||
isSending = true;
|
isSending = true;
|
||||||
StateHasChanged();
|
StateHasChanged();
|
||||||
await Task.Delay(3000);
|
await Task.Delay(3000);
|
||||||
//isSending = false;
|
|
||||||
messages = null;
|
if (string.IsNullOrWhiteSpace(TextValue))
|
||||||
|
{
|
||||||
|
Snackbar.Add("Missing input text?", Severity.Error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var message = new Message
|
||||||
|
{
|
||||||
|
Content = TextValue,
|
||||||
|
DatePosted = DateTimeOffset.Now.ToUnixTimeSeconds(),
|
||||||
|
Name = Program.LoggedInName
|
||||||
|
};
|
||||||
|
|
||||||
|
await messageService.AddMessage(message);
|
||||||
|
TextValue = string.Empty;
|
||||||
|
messages = await messageService.GetMessages();
|
||||||
|
isSending = false;
|
||||||
NavManager.NavigateTo("/");
|
NavManager.NavigateTo("/");
|
||||||
NavManager.NavigateTo("/Chatting");
|
NavManager.NavigateTo("/Chatting");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private IEnumerable<string> MaxCharacters(string ch)
|
||||||
|
{
|
||||||
|
if (!string.IsNullOrEmpty(ch) && 32 < ch?.Length)
|
||||||
|
yield return "Max 32 characters";
|
||||||
|
}
|
||||||
|
|
||||||
Message[]? messages;
|
Message[]? messages;
|
||||||
|
|
||||||
protected override async Task OnInitializedAsync()
|
protected override async Task OnInitializedAsync()
|
||||||
{
|
{
|
||||||
messages = (await Http.GetFromJsonAsync<Message[]>("https://globalchat-4a89f-default-rtdb.europe-west1.firebasedatabase.app/Database/Messages.json"));
|
messages = await messageService.GetMessages();
|
||||||
|
|
||||||
StartLoop();
|
StartLoop();
|
||||||
}
|
}
|
||||||
|
@ -103,9 +127,10 @@
|
||||||
|
|
||||||
while (isLooping)
|
while (isLooping)
|
||||||
{
|
{
|
||||||
messages = (await Http.GetFromJsonAsync<Message[]>("https://globalchat-4a89f-default-rtdb.europe-west1.firebasedatabase.app/Database/Messages.json"));
|
messages = await messageService.GetMessages();
|
||||||
|
Console.WriteLine("Chat updated!");
|
||||||
|
|
||||||
await Task.Delay(100000); // Delay for 1 second before the next iteration
|
await Task.Delay(10000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,8 @@ internal class Program
|
||||||
builder.Services.AddBlazoredLocalStorage(config =>
|
builder.Services.AddBlazoredLocalStorage(config =>
|
||||||
config.JsonSerializerOptions.WriteIndented = true); // local storage
|
config.JsonSerializerOptions.WriteIndented = true); // local storage
|
||||||
|
|
||||||
|
builder.Services.AddScoped<MessageService>();
|
||||||
|
|
||||||
await builder.Build().RunAsync();
|
await builder.Build().RunAsync();
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
using System;
|
||||||
|
using System.Net.Http;
|
||||||
|
using System.Net.Http.Json;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using static Otakians.Pages.Chatting;
|
||||||
|
|
||||||
|
public class MessageService
|
||||||
|
{
|
||||||
|
private readonly HttpClient _httpClient;
|
||||||
|
private const string ApiUrl = "https://globalchat-4a89f-default-rtdb.europe-west1.firebasedatabase.app/Database.json";
|
||||||
|
|
||||||
|
public MessageService(HttpClient httpClient)
|
||||||
|
{
|
||||||
|
_httpClient = httpClient;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<Message[]?> GetMessages()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var rawMaybe = await _httpClient.GetFromJsonAsync<Dictionary<string, Message>>(ApiUrl);
|
||||||
|
|
||||||
|
if (rawMaybe == null) return null;
|
||||||
|
|
||||||
|
Message[] messages = rawMaybe.Values.ToArray();
|
||||||
|
Array.Reverse(messages);
|
||||||
|
return messages;
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
// Handle exception appropriately (e.g., log, display an error message)
|
||||||
|
throw ex;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task AddMessage(Message message)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
await _httpClient.PostAsJsonAsync(ApiUrl, message);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
// Handle exception appropriately (e.g., log, display an error message)
|
||||||
|
throw ex;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,4 +7,4 @@
|
||||||
@using Microsoft.JSInterop
|
@using Microsoft.JSInterop
|
||||||
@using Otakians
|
@using Otakians
|
||||||
@using MudBlazor
|
@using MudBlazor
|
||||||
@using System.Text.Json;
|
@using System.Text.Json;
|
|
@ -9,8 +9,6 @@
|
||||||
<link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap" rel="stylesheet" />
|
<link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap" rel="stylesheet" />
|
||||||
<link href="_content/MudBlazor/MudBlazor.min.css" rel="stylesheet" />
|
<link href="_content/MudBlazor/MudBlazor.min.css" rel="stylesheet" />
|
||||||
<link href="css/MudBlazor.min.css" rel="stylesheet" />
|
<link href="css/MudBlazor.min.css" rel="stylesheet" />
|
||||||
|
|
||||||
|
|
||||||
<!-- If you add any scoped CSS files, uncomment the following to load them
|
<!-- If you add any scoped CSS files, uncomment the following to load them
|
||||||
<link href="Otakians.styles.css" rel="stylesheet" /> -->
|
<link href="Otakians.styles.css" rel="stylesheet" /> -->
|
||||||
</head>
|
</head>
|
||||||
|
|
Loading…
Reference in New Issue