@using ImageBoardServerApp.Auth
@using ImageBoardServerApp.Data.Repository
@using ImageBoardServerApp.Util
@using System.Text.RegularExpressions
@using System.ComponentModel.DataAnnotations
@inject AuthenticationStateProvider authStateProvider
@code {
private string reportURL { get; set; }
private bool isActive { get; set; } = false;
private (int x, int y, int p) hoveringOver { get; set; } = (-1, -1, -1);
private Dictionary isComment{ get; set; }
private Dictionary hoverComment { get; set; }
private Dictionary hoverPost { get; set; }
private Dictionary nrToGet { get; set; }
private void onHover(int x, int y, int p)
{
if (hoverComment.ContainsKey(p) || hoverPost.ContainsKey(p))
{
hoveringOver= (x, y, -1);
}
hoveringOver = (x, y, p);
}
public bool canDel { get; set; }
private async Task deletePost()
{
var cauthStateProvder = (CustomAuthenticationStateProvider)authStateProvider;
var user = await cauthStateProvder.GetAuthenticationStateAsync();
var usr = user.User;
UserData foundusr = await UsersRepository.getUserByIdAsync(int.Parse(usr.Identity.Name));
if (foundusr.Role != "User" || comment.UserID == foundusr.UserID)
{
await TheManager.deleteComment(comment);
}
}
private static DateTime getTimeFromUnix(double javaTimeStamp)
{
var dateTime = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
dateTime = dateTime.AddMilliseconds( javaTimeStamp ).ToLocalTime();
return dateTime;
}
private ImageData image;
private string role;
protected override async Task OnParametersSetAsync()
{
await base.OnParametersSetAsync();
var cauthStateProvder = (CustomAuthenticationStateProvider)authStateProvider;
var user = await cauthStateProvder.GetAuthenticationStateAsync();
var usr = user.User;
UserData foundusr = await UsersRepository.getUserByIdAsync(int.Parse(usr.Identity.Name));
if (foundusr != null && (foundusr.Role != "User" || comment.UserID == foundusr.UserID))
{
canDel = true;
}
else
{
canDel = false;
}
hoverComment = new Dictionary();
hoverPost = new Dictionary();
nrToGet = new Dictionary();
isComment = new Dictionary();
foreach (string s in comment.Content.Split("\n"))
{
@foreach (string line in s.Split(" "))
{
@if (Regex.IsMatch(line, ">>\\d+"))
{
var commentNumber = int.Parse(Regex.Match(s, ">>(\\d+)").Value.Substring(2));
string board = comment.Board;
if (await TheManager.isGETComment(board, commentNumber))
{
CommentData c = await CommentsRepository.getCommentByGETAsync(board, commentNumber);
if (c == null)
continue;
hoverComment[commentNumber] = c;
nrToGet[commentNumber] = c.GET;
isComment[commentNumber] = true;
}
else
{
PostData p = await PostsRepository.getPostByGETAsync(board, commentNumber);
if (p == null)
continue;
hoverPost[commentNumber] = p;
nrToGet[commentNumber] = p.GET;
isComment[commentNumber] = false;
}
}
}
}
reportURL = $"/sys/report/comment/{comment.Board}/{comment.CommentID}";
}
protected override async Task OnInitializedAsync()
{
int i;
try
{
i = (int)comment.ImageID;
}
catch (InvalidOperationException ioe)
{
i = -1;
}
if (i != null)
{
image = await ImagesRepository.getImageByIdAsync(i);
}
var cmt = await CommentsRepository.getCommentByIdAsync(comment.CommentID);
role = cmt.User.Role;
}
private bool opened = true;
private string toggleText = "-";
private void ToggleOpened()
{
opened = !opened;
toggleText = opened ? "-" : "+";
}
private string toggleText2 = "-";
private bool showHover = false;
private void ToggleHovered(MouseEventArgs e, string id)
{
showHover = !showHover;
toggleText2 = showHover ? "-" : "+";
}
[Parameter]
[Required]
public CommentData comment { get; set; }
}