Save
This commit is contained in:
@ -1,13 +1,181 @@
|
||||
@page "/administration"
|
||||
@inherits PagesBase
|
||||
|
||||
<Title>@CascadingState.Localizer["Settings"]</Title>
|
||||
|
||||
<section class="block relative w-full h-full neomorphInset is-nxsmall rounded-xl">
|
||||
|
||||
<div class="flex flex-col space-y-4 p-4 md:p-5 w-full h-full absolute overflow-y-auto">
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Users"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Reports"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["ActivityPub?"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Authentication"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Emoji?"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Frontend"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Instance"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Link formatter"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Metadata"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Policies"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-albums text-xl"></i> <span>@CascadingState.Localizer["Upload"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
<div class="block w-full p-3 md:p-4">
|
||||
<p class="w-full text-center text-lg">
|
||||
<i class="ion-ios-remove-circle-outline"></i> @CascadingState.Localizer["Empty"]
|
||||
</p>
|
||||
</div>
|
||||
</InnerContent>
|
||||
</OpenDownContainer>
|
||||
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
@code {
|
||||
|
||||
[CascadingParameter] CascadingState CascadingState { get; set; }
|
||||
}
|
||||
|
@ -10,7 +10,7 @@
|
||||
|
||||
@if (IsLoading)
|
||||
{
|
||||
<LoadingData/>
|
||||
<LoadingData />
|
||||
}
|
||||
|
||||
@foreach (var message in Ancestors)
|
||||
@ -86,7 +86,8 @@
|
||||
Medias = new(),
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
BoostsCounter = Random.Shared.Next(0,100),
|
||||
IsBoostedByCurrentUser = Random.Shared.Next() % 2 == 0,
|
||||
}
|
||||
};
|
||||
|
||||
@ -103,7 +104,8 @@
|
||||
Medias = new(),
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
BoostsCounter = Random.Shared.Next(0,100),
|
||||
IsBoostedByCurrentUser = Random.Shared.Next() % 2 == 0,
|
||||
}
|
||||
};
|
||||
IsLoading = false;
|
||||
@ -116,9 +118,6 @@
|
||||
|
||||
async Task OnMessageReply(MessageForm messageForm)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
var replyMessage = await MessagesService.SubmitMessage(messageForm);
|
||||
Descendants.Add(new()
|
||||
{
|
||||
@ -149,59 +148,41 @@
|
||||
|
||||
async ValueTask OnMessageBoost(Message message)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
message.IsBoosted = !message.IsBoosted;
|
||||
if (message.IsBoostedByCurrentUser) return;
|
||||
var boostedMessage = await MessagesService.BoostUnboostMessage(message);
|
||||
message.BoostsCounter += 1;
|
||||
|
||||
//Add to the home page in the background
|
||||
}
|
||||
|
||||
async ValueTask OnMessageFavourite(Message message)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
message.IsFavourite = !message.IsFavourite;
|
||||
var favouriteMessage = await MessagesService.FavouriteUnfavouriteMessage(message);
|
||||
message.IsFavourite = !message.IsFavourite;
|
||||
}
|
||||
|
||||
async ValueTask OnMessageDelete(Message message)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
var deleteResult = await MessagesService.DeleteMessage(message);
|
||||
}
|
||||
|
||||
async ValueTask OnMessageMediaDownload(Media media)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
await BlazorDownloadFileService.DownloadFileAsync(media.FileName, media.Blob, media.ContentType);
|
||||
}
|
||||
|
||||
async ValueTask OnUserBlock(MessageUser messageUser)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
var blockResult = await MessagesService.BlockUserFromMessage(messageUser);
|
||||
}
|
||||
|
||||
async ValueTask OnUserDirectMessage(Message message)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
var directMessage = await MessagesService.ReplyMessage(message, MessageType.Direct);
|
||||
}
|
||||
|
||||
async ValueTask OnUserSilence(MessageUser messageUser)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
});
|
||||
var silenceResult = await MessagesService.SilenceUserFromMessage(messageUser);
|
||||
}
|
||||
}
|
@ -11,7 +11,7 @@
|
||||
|
||||
@if (IsLoading)
|
||||
{
|
||||
<LoadingData/>
|
||||
<LoadingData />
|
||||
}
|
||||
else if (Messages.Count == 0)
|
||||
{
|
||||
@ -183,8 +183,39 @@
|
||||
|
||||
async ValueTask OnMessageBoost(Message message)
|
||||
{
|
||||
message.IsBoosted = !message.IsBoosted;
|
||||
var boostedMessage = await MessagesService.BoostUnboostMessage(message);
|
||||
var boostedMessageTemp = await MessagesService.BoostUnboostMessage(message);
|
||||
message.BoostsCounter = message.IsBoostedByCurrentUser ? message.BoostsCounter - 1 : message.BoostsCounter + 1;
|
||||
message.IsBoostedByCurrentUser = !message.IsBoostedByCurrentUser;
|
||||
if (message.IsBoostedByCurrentUser)
|
||||
{
|
||||
var boostedMessage = new Message
|
||||
{
|
||||
BoostingUser = new()
|
||||
{
|
||||
UserId = CascadingState.User.Id,
|
||||
DisplayName = CascadingState.User.DisplayName,
|
||||
PictureUrl = CascadingState.User.PictureUrl,
|
||||
ProfileUrl = CascadingState.User.ProfileUrl,
|
||||
UserName = CascadingState.User.UserName
|
||||
},
|
||||
BoostsCounter = message.BoostsCounter,
|
||||
Content = message.Content,
|
||||
CreatedAt = message.CreatedAt,
|
||||
IsBoostedByCurrentUser = true,
|
||||
IsFavourite = message.IsFavourite,
|
||||
Medias = message.Medias,
|
||||
MessageId = message.MessageId,
|
||||
MessageType = message.MessageType,
|
||||
RootMessageId = message.RootMessageId,
|
||||
Title = message.Title,
|
||||
User = message.User
|
||||
};
|
||||
Messages.Insert(0, boostedMessage);
|
||||
}
|
||||
else
|
||||
{
|
||||
Messages.RemoveAll(m => m.MessageId == message.MessageId && m.BoostingUser != null && m.BoostingUser.UserId == CascadingState.User.Id);
|
||||
}
|
||||
}
|
||||
|
||||
async ValueTask OnMessageFavourite(Message message)
|
||||
|
@ -9,7 +9,7 @@
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-cog text-lg"></i> @CascadingState.Localizer["General"]
|
||||
<i class="ion-md-cog text-xl"></i> <span>@CascadingState.Localizer["General"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
@ -24,7 +24,7 @@
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-person text-lg"></i> @CascadingState.Localizer["Profile"]
|
||||
<i class="ion-md-person text-xl"></i> <span>@CascadingState.Localizer["Profile"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
@ -39,7 +39,7 @@
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-archive text-lg"></i> @CascadingState.Localizer["Data import/export"]
|
||||
<i class="ion-md-archive text-xl"></i> <span>@CascadingState.Localizer["Data import/export"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
@ -54,7 +54,7 @@
|
||||
<OpenDownContainer>
|
||||
<TitleChildren>
|
||||
<p class="inline-flex items-center space-x-2">
|
||||
<i class="ion-md-eye-off text-lg"></i> @CascadingState.Localizer["Mutes/Blocks"]
|
||||
<i class="ion-md-eye-off text-xl"></i> <span>@CascadingState.Localizer["Mutes/Blocks"]</span>
|
||||
</p>
|
||||
</TitleChildren>
|
||||
<InnerContent>
|
||||
|
Reference in New Issue
Block a user