Fix #3885: only re-render the component when message changed.
This commit is contained in:
parent
4b1f23a189
commit
2b32f316ee
|
@ -12,12 +12,13 @@
|
||||||
{
|
{
|
||||||
<NavLink class="ms-2" href="@NavigateUrl("admin/log")">View Details</NavLink>
|
<NavLink class="ms-2" href="@NavigateUrl("admin/log")">View Details</NavLink>
|
||||||
}
|
}
|
||||||
<a href="@NavigationManager.Uri" class="btn-close" data-dismiss="alert" aria-label="close"></a>
|
<button type="button" class="btn-close" data-dismiss="alert" aria-label="close" @onclick="CloseMessage"></button>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
|
private string _message = string.Empty;
|
||||||
private string _classname = string.Empty;
|
private string _classname = string.Empty;
|
||||||
private string _formname = "ModuleMessageForm";
|
private string _formname = "ModuleMessageForm";
|
||||||
|
|
||||||
|
@ -27,15 +28,8 @@
|
||||||
[Parameter]
|
[Parameter]
|
||||||
public MessageType Type { get; set; }
|
public MessageType Type { get; set; }
|
||||||
|
|
||||||
public void RefreshMessage(string message, MessageType type)
|
[Parameter]
|
||||||
{
|
public RenderModeBoundary Parent { get; set; }
|
||||||
Message = message;
|
|
||||||
Type = type;
|
|
||||||
|
|
||||||
UpdateClassName();
|
|
||||||
|
|
||||||
StateHasChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnInitialized()
|
protected override void OnInitialized()
|
||||||
{
|
{
|
||||||
|
@ -47,12 +41,8 @@
|
||||||
|
|
||||||
protected override void OnParametersSet()
|
protected override void OnParametersSet()
|
||||||
{
|
{
|
||||||
UpdateClassName();
|
_message = Message;
|
||||||
}
|
if (!string.IsNullOrEmpty(_message))
|
||||||
|
|
||||||
private void UpdateClassName()
|
|
||||||
{
|
|
||||||
if (!string.IsNullOrEmpty(Message))
|
|
||||||
{
|
{
|
||||||
_classname = GetMessageType(Type);
|
_classname = GetMessageType(Type);
|
||||||
}
|
}
|
||||||
|
@ -79,4 +69,15 @@
|
||||||
|
|
||||||
return classname;
|
return classname;
|
||||||
}
|
}
|
||||||
|
private void CloseMessage(MouseEventArgs e)
|
||||||
|
{
|
||||||
|
if(Parent != null)
|
||||||
|
{
|
||||||
|
Parent.DismissMessage();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
NavigationManager.NavigateTo(NavigationManager.Uri);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -278,7 +278,6 @@ namespace Oqtane.Modules
|
||||||
|
|
||||||
public void AddModuleMessage(string message, MessageType type, string position)
|
public void AddModuleMessage(string message, MessageType type, string position)
|
||||||
{
|
{
|
||||||
ClearModuleMessage();
|
|
||||||
RenderModeBoundary.AddModuleMessage(message, type, position);
|
RenderModeBoundary.AddModuleMessage(message, type, position);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,13 +10,19 @@
|
||||||
{
|
{
|
||||||
@if (ModuleType != null)
|
@if (ModuleType != null)
|
||||||
{
|
{
|
||||||
<ModuleMessage @ref="moduleMessageTop" Message="@_messageContent" Type="@_messageType" />
|
@if (!string.IsNullOrEmpty(_messageContent) && _messagePosition == "top")
|
||||||
|
{
|
||||||
|
<ModuleMessage Message="@_messageContent" Type="@_messageType" Parent="@this" />
|
||||||
|
}
|
||||||
@DynamicComponent
|
@DynamicComponent
|
||||||
@if (_progressIndicator)
|
@if (_progressIndicator)
|
||||||
{
|
{
|
||||||
<div class="app-progress-indicator"></div>
|
<div class="app-progress-indicator"></div>
|
||||||
}
|
}
|
||||||
<ModuleMessage @ref="moduleMessageBottom" Message="@_messageContent" Type="@_messageType" />
|
@if (!string.IsNullOrEmpty(_messageContent) && _messagePosition == "bottom")
|
||||||
|
{
|
||||||
|
<ModuleMessage Message="@_messageContent" Type="@_messageType" Parent="@this" />
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -41,8 +47,6 @@
|
||||||
private string _messagePosition;
|
private string _messagePosition;
|
||||||
private bool _progressIndicator = false;
|
private bool _progressIndicator = false;
|
||||||
private string _error;
|
private string _error;
|
||||||
private ModuleMessage moduleMessageTop;
|
|
||||||
private ModuleMessage moduleMessageBottom;
|
|
||||||
|
|
||||||
[Parameter]
|
[Parameter]
|
||||||
public SiteState SiteState { get; set; }
|
public SiteState SiteState { get; set; }
|
||||||
|
@ -103,12 +107,17 @@
|
||||||
|
|
||||||
public void AddModuleMessage(string message, MessageType type, string position)
|
public void AddModuleMessage(string message, MessageType type, string position)
|
||||||
{
|
{
|
||||||
_messageContent = message;
|
if(message != _messageContent
|
||||||
_messageType = type;
|
|| type != _messageType
|
||||||
_messagePosition = position;
|
|| position != _messagePosition)
|
||||||
_progressIndicator = false;
|
{
|
||||||
|
_messageContent = message;
|
||||||
|
_messageType = type;
|
||||||
|
_messagePosition = position;
|
||||||
|
_progressIndicator = false;
|
||||||
|
|
||||||
Refresh();
|
StateHasChanged();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ShowProgressIndicator()
|
public void ShowProgressIndicator()
|
||||||
|
@ -123,25 +132,10 @@
|
||||||
StateHasChanged();
|
StateHasChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void DismissMessage()
|
public void DismissMessage()
|
||||||
{
|
{
|
||||||
_messageContent = "";
|
_messageContent = "";
|
||||||
}
|
StateHasChanged();
|
||||||
|
|
||||||
private void Refresh()
|
|
||||||
{
|
|
||||||
var updateTop = string.IsNullOrEmpty(_messageContent) || _messagePosition == "top";
|
|
||||||
var updateBottom = string.IsNullOrEmpty(_messageContent) || _messagePosition == "bottom";
|
|
||||||
|
|
||||||
if (updateTop && moduleMessageTop != null)
|
|
||||||
{
|
|
||||||
moduleMessageTop.RefreshMessage(_messageContent, _messageType);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (updateBottom && moduleMessageBottom != null)
|
|
||||||
{
|
|
||||||
moduleMessageBottom.RefreshMessage(_messageContent, _messageType);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override async Task OnErrorAsync(Exception exception)
|
protected override async Task OnErrorAsync(Exception exception)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user