Skip to content

963343: Render Diagram when opens Dialog #137

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 13 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/App.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
@namespace DiagramInDialog
<Router AppAssembly="@typeof(App).Assembly">
<Found Context="routeData">
<RouteView RouteData="@routeData" DefaultLayout="@typeof(MainLayout)" />
<FocusOnNavigate RouteData="@routeData" Selector="h1" />
</Found>
<NotFound>
<PageTitle>Not found</PageTitle>
<LayoutView Layout="@typeof(MainLayout)">
<p role="alert">Sorry, there's nothing at this address.</p>
</LayoutView>
</NotFound>
</Router>
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
<Project Sdk="Microsoft.NET.Sdk.Web">

<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
<Nullable>enable</Nullable>
<ImplicitUsings>enable</ImplicitUsings>
</PropertyGroup>

<ItemGroup>
<PackageReference Include="Syncfusion.Blazor.Diagram" Version="*" />
<PackageReference Include="Syncfusion.Blazor.Themes" Version="*" />
</ItemGroup>

</Project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<ActiveDebugProfile>https</ActiveDebugProfile>
</PropertyGroup>
</Project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
<Project Sdk="Microsoft.NET.Sdk.Web">

<PropertyGroup>
<TargetFramework>net9.0</TargetFramework>
<Nullable>enable</Nullable>
<ImplicitUsings>enable</ImplicitUsings>
</PropertyGroup>

<ItemGroup>
<PackageReference Include="Syncfusion.Blazor.Diagram" Version="*" />
<PackageReference Include="Syncfusion.Blazor.Themes" Version="*" />
</ItemGroup>

</Project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<ActiveDebugProfile>https</ActiveDebugProfile>
</PropertyGroup>
</Project>
3 changes: 3 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/MainLayout.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
@inherits LayoutComponentBase
@namespace DiagramInDialog
<main> @Body </main>
132 changes: 132 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/Pages/Index.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
@page "/"

@using Syncfusion.Blazor.Buttons
@using Syncfusion.Blazor.Popups
@using Syncfusion.Blazor.Diagram
@using System.Collections.ObjectModel
@inject IJSRuntime jsRuntime;

<div id="target" style="height:100%">
<SfButton CssClass="e-primary" @onclick="ShowDialog">Open Diagram Dialog</SfButton>
</div>

<SfDialog ShowCloseIcon="true"
Width="707px"
Height="1000px"
IsModal="true"
Target="#target"
AllowPrerender="true"
@ref="_dialog"
Visible="@IsDialogVisible">
<DialogEvents OnOpen="OpenDialog" OnClose="CloseDialog" Opened="OpenedDialog"></DialogEvents>
<DialogAnimationSettings Effect="@DialogEffect.Zoom"></DialogAnimationSettings>
<DialogTemplates>
<Header>
<div id="template" class="e-icon-settings">E-mail Diagram</div>
</Header>
<Content>
<SfDiagramComponent @ref="Diagram"
InteractionController="DiagramInteractions.ZoomPan"
NodeCreating="NodeDefaults"
ConnectorCreating="ConnectorDefaults">
<SnapSettings Constraints="SnapConstraints.None"></SnapSettings>
<DataSourceSettings ID="Id"
ParentID="ParentId"
DataSource="@DataSource">
</DataSourceSettings>
<Layout Type="LayoutType.HierarchicalTree"
HorizontalSpacing="@HorizontalSpacing"
VerticalSpacing="@VerticalSpacing">
</Layout>
</SfDiagramComponent>
</Content>
</DialogTemplates>
</SfDialog>

@code {
private SfDialog _dialog;
private SfDiagramComponent Diagram;

private bool IsDialogVisible = false;

private int HorizontalSpacing { get; set; } = 50;
private int VerticalSpacing { get; set; } = 50;
bool open = false;
public ObservableCollection<DiagramData> DataSource { get; set; } = new()
{
new DiagramData { Id = "1", ParentId = "", Label = "CEO" },
new DiagramData { Id = "2", ParentId = "1", Label = "Manager" },
new DiagramData { Id = "3", ParentId = "2", Label = "Team Lead" },
new DiagramData { Id = "4", ParentId = "3", Label = "Senior Developer" },
new DiagramData { Id = "5", ParentId = "4", Label = "Developer" },
new DiagramData { Id = "6", ParentId = "5", Label = "Fresher" }
};

public class DiagramData
{
public string Id { get; set; }
public string ParentId { get; set; }
public string Label { get; set; }
}

private async Task ShowDialog()
{
IsDialogVisible = true;
}
private async Task OpenDialog(BeforeOpenEventArgs args)
{
await jsRuntime.InvokeAsync<object>("UpdateWindow").ConfigureAwait(true);
open = true;
}
protected override async Task OnAfterRenderAsync(bool firstRender)
{
await base.OnAfterRenderAsync(firstRender);
if (open && Diagram != null)
{
await Task.Delay(1000);
Diagram.FitToPage(new FitOptions() { Mode = FitMode.Both, Region = DiagramRegion.Content });
open = false;
}
}


private void CloseDialog(BeforeCloseEventArgs args)
{
IsDialogVisible = false;
}

private void NodeDefaults(IDiagramObject obj)
{
if (obj is Node node)
{
node.Width = 100;
node.Height = 40;
node.Style = new ShapeStyle { Fill = "#6BA5D7", StrokeColor = "white" };
}
}

private void ConnectorDefaults(IDiagramObject obj)
{
if (obj is Connector connector)
{
connector.Type = ConnectorSegmentType.Orthogonal;
connector.Style = new ShapeStyle { StrokeColor = "#6BA5D7", StrokeWidth = 2 };
}
}

private void OpenedDialog()
{
FitOptions Options = new FitOptions()
{
Mode = FitMode.Both,
Region = DiagramRegion.Content
};
Diagram.FitToPage(Options);
}
}

<style>
#target {
min-height: 660px;
}
</style>
33 changes: 33 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/Pages/_Host.cshtml
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
@page "/"
@using Microsoft.AspNetCore.Components.Web
@namespace DiagramInDialog.Pages
@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<base href="~/" />
<link href="css/site.css" rel="stylesheet" />
<link href="_content/Syncfusion.Blazor.Themes/bootstrap5.3.css" rel="stylesheet" />
<script src="_content/Syncfusion.Blazor.Core/scripts/syncfusion-blazor.min.js" type="text/javascript"></script>
<script src="~/interop.js"></script>
<component type="typeof(HeadOutlet)" render-mode="ServerPrerendered" />
</head>
<body>
<component type="typeof(App)" render-mode="ServerPrerendered" />

<div id="blazor-error-ui">
<environment include="Staging,Production">
An error has occurred. This application may no longer respond until reloaded.
</environment>
<environment include="Development">
An unhandled exception has occurred. See browser dev tools for details.
</environment>
<a href="" class="reload">Reload</a>
<a class="dismiss">🗙</a>
</div>

<script src="_framework/blazor.server.js"></script>
</body>
</html>
28 changes: 28 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/Program.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
using Microsoft.AspNetCore.Components;
using Microsoft.AspNetCore.Components.Web;
using Syncfusion.Blazor;
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddRazorPages();
builder.Services.AddServerSideBlazor();
builder.Services.AddSyncfusionBlazor();
builder.Services.AddSignalR(e => {
e.MaximumReceiveMessageSize = 102400000;
});
var app = builder.Build();

if (!app.Environment.IsDevelopment())
{
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}

app.UseHttpsRedirection();

app.UseStaticFiles();

app.UseRouting();

app.MapBlazorHub();
app.MapFallbackToPage("/_Host");

app.Run();
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
{
"iisSettings": {
"iisExpress": {
"applicationUrl": "http://localhost:18318",
"sslPort": 44368
}
},
"profiles": {
"http": {
"commandName": "Project",
"dotnetRunMessages": true,
"launchBrowser": true,
"applicationUrl": "http://localhost:5048",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"https": {
"commandName": "Project",
"dotnetRunMessages": true,
"launchBrowser": true,
"applicationUrl": "https://localhost:7088;http://localhost:5048",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"IIS Express": {
"commandName": "IISExpress",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
}
}
5 changes: 5 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/_Imports.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
@using Microsoft.AspNetCore.Components.Routing
@using Microsoft.AspNetCore.Components.Web
@using Microsoft.JSInterop
@using DiagramInDialog

Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"DetailedErrors": true,
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
}
}
9 changes: 9 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/appsettings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*"
}
3 changes: 3 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/wwwroot/Interop.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
function UpdateWindow() {
window.dispatchEvent(new Event('resize'));
}
28 changes: 28 additions & 0 deletions KB-Samples/DiagramInDialog/DiagramInDialog/wwwroot/css/site.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
#blazor-error-ui {
background: lightyellow;
bottom: 0;
box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
display: none;
left: 0;
padding: 0.6rem 1.25rem 0.7rem 1.25rem;
position: fixed;
width: 100%;
z-index: 1000;
}

#blazor-error-ui .dismiss {
cursor: pointer;
position: absolute;
right: 3.5rem;
top: 0.5rem;
}

.blazor-error-boundary {
background: url() no-repeat 1rem/1.8rem, #b32121;
padding: 1rem 1rem 1rem 3.7rem;
color: white;
}

.blazor-error-boundary::after {
content: "An error has occurred."
}