diff --git a/Oqtane.Client/Modules/Controls/ModuleMessage.razor b/Oqtane.Client/Modules/Controls/ModuleMessage.razor
index 76b6b6425..b99704750 100644
--- a/Oqtane.Client/Modules/Controls/ModuleMessage.razor
+++ b/Oqtane.Client/Modules/Controls/ModuleMessage.razor
@@ -2,10 +2,10 @@
@inherits ModuleControlBase
@inject NavigationManager NavigationManager
-@if (!string.IsNullOrEmpty(_message))
+@if (Visible)
{
- @((MarkupString)_message)
+ @((MarkupString)Message)
@if (PageState != null)
{
@if (Type == MessageType.Error && UserSecurity.IsAuthorized(PageState.User, RoleNames.Host))
@@ -21,7 +21,6 @@
}
@code {
- private string _message = string.Empty;
private string _classname = string.Empty;
private string _formname = "ModuleMessageForm";
@@ -31,6 +30,20 @@
[Parameter]
public MessageType Type { get; set; }
+ [Parameter]
+ public bool Visible { get; set; } = true;
+
+ public void RefreshMessage(string message, MessageType type, bool visible)
+ {
+ Message = message;
+ Type = type;
+ Visible = visible;
+
+ UpdateClassName();
+
+ StateHasChanged();
+ }
+
protected override void OnInitialized()
{
if (ModuleState != null)
@@ -41,8 +54,12 @@
protected override void OnParametersSet()
{
- _message = Message;
- if (!string.IsNullOrEmpty(_message))
+ UpdateClassName();
+ }
+
+ private void UpdateClassName()
+ {
+ if (!string.IsNullOrEmpty(Message))
{
_classname = GetMessageType(Type);
}
@@ -72,6 +89,6 @@
private void DismissModal()
{
- _message = "";
+ Message = "";
}
}
diff --git a/Oqtane.Client/UI/RenderModeBoundary.razor b/Oqtane.Client/UI/RenderModeBoundary.razor
index 094797679..05509b0f3 100644
--- a/Oqtane.Client/UI/RenderModeBoundary.razor
+++ b/Oqtane.Client/UI/RenderModeBoundary.razor
@@ -11,19 +11,13 @@
@if (ModuleType != null)
{
@((MarkupString)$"")
- @if (!string.IsNullOrEmpty(_messageContent) && _messagePosition == "top")
- {
-
- }
+
@DynamicComponent
@if (_progressIndicator)
{
}
- @if (!string.IsNullOrEmpty(_messageContent) && _messagePosition == "bottom")
- {
-
- }
+
}
}
else
@@ -48,6 +42,8 @@
private string _messagePosition;
private bool _progressIndicator = false;
private string _error;
+ private ModuleMessage moduleMessageTop;
+ private ModuleMessage moduleMessageBottom;
[Parameter]
public SiteState SiteState { get; set; }
@@ -112,19 +108,20 @@
_messageType = type;
_messagePosition = position;
_progressIndicator = false;
- StateHasChanged();
+
+ Refresh();
}
public void ShowProgressIndicator()
{
_progressIndicator = true;
- StateHasChanged();
+ Refresh();
}
public void HideProgressIndicator()
{
_progressIndicator = false;
- StateHasChanged();
+ Refresh();
}
private void DismissMessage()
@@ -132,6 +129,22 @@
_messageContent = "";
}
+ private void Refresh()
+ {
+ var messageTopVisible = !string.IsNullOrEmpty(_messageContent) && _messagePosition == "top";
+ var messageBottomVisible = !string.IsNullOrEmpty(_messageContent) && _messagePosition == "bottom";
+
+ if (moduleMessageTop != null)
+ {
+ moduleMessageTop.RefreshMessage(_messageContent, _messageType, messageTopVisible);
+ }
+
+ if (moduleMessageBottom != null)
+ {
+ moduleMessageBottom.RefreshMessage(_messageContent, _messageType, messageBottomVisible);
+ }
+ }
+
protected override async Task OnErrorAsync(Exception exception)
{
// retrieve friendly localized error