Skip to content
Merged
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
3 changes: 3 additions & 0 deletions Spreadsheet/BlazorWASMApp/SpreadSheetSample.slnx
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<Solution>
<Project Path="SpreadSheetSample/SpreadSheetSample.csproj" />
</Solution>
6 changes: 6 additions & 0 deletions Spreadsheet/BlazorWASMApp/SpreadSheetSample/App.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
<Router AppAssembly="@typeof(App).Assembly" NotFoundPage="typeof(Pages.NotFound)">
<Found Context="routeData">
<RouteView RouteData="@routeData" DefaultLayout="@typeof(MainLayout)"/>
<FocusOnNavigate RouteData="@routeData" Selector="h1" />
</Found>
</Router>
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
@inherits LayoutComponentBase
<div class="page">
<div class="sidebar">
<NavMenu />
</div>

<main>
<div class="top-row px-4">
<a href="https://learn.microsoft.com/aspnet/core/" target="_blank">About</a>
</div>

<article class="content px-4">
@Body
</article>
</main>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
.page {
position: relative;
display: flex;
flex-direction: column;
}

main {
flex: 1;
}

.sidebar {
background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
}

.top-row {
background-color: #f7f7f7;
border-bottom: 1px solid #d6d5d5;
justify-content: flex-end;
height: 3.5rem;
display: flex;
align-items: center;
}

.top-row ::deep a, .top-row ::deep .btn-link {
white-space: nowrap;
margin-left: 1.5rem;
text-decoration: none;
}

.top-row ::deep a:hover, .top-row ::deep .btn-link:hover {
text-decoration: underline;
}

.top-row ::deep a:first-child {
overflow: hidden;
text-overflow: ellipsis;
}

@media (max-width: 640.98px) {
.top-row {
justify-content: space-between;
}

.top-row ::deep a, .top-row ::deep .btn-link {
margin-left: 0;
}
}

@media (min-width: 641px) {
.page {
flex-direction: row;
}

.sidebar {
width: 250px;
height: 100vh;
position: sticky;
top: 0;
}

.top-row {
position: sticky;
top: 0;
z-index: 1;
}

.top-row.auth ::deep a:first-child {
flex: 1;
text-align: right;
width: 0;
}

.top-row, article {
padding-left: 2rem !important;
padding-right: 1.5rem !important;
}
}
39 changes: 39 additions & 0 deletions Spreadsheet/BlazorWASMApp/SpreadSheetSample/Layout/NavMenu.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
<div class="top-row ps-3 navbar navbar-dark">
<div class="container-fluid">
<a class="navbar-brand" href="">SpreadSheetSample</a>
<button title="Navigation menu" class="navbar-toggler" @onclick="ToggleNavMenu">
<span class="navbar-toggler-icon"></span>
</button>
</div>
</div>

<div class="@NavMenuCssClass nav-scrollable" @onclick="ToggleNavMenu">
<nav class="nav flex-column">
<div class="nav-item px-3">
<NavLink class="nav-link" href="" Match="NavLinkMatch.All">
<span class="bi bi-house-door-fill-nav-menu" aria-hidden="true"></span> Home
</NavLink>
</div>
<div class="nav-item px-3">
<NavLink class="nav-link" href="counter">
<span class="bi bi-plus-square-fill-nav-menu" aria-hidden="true"></span> Counter
</NavLink>
</div>
<div class="nav-item px-3">
<NavLink class="nav-link" href="weather">
<span class="bi bi-list-nested-nav-menu" aria-hidden="true"></span> Weather
</NavLink>
</div>
</nav>
</div>

@code {
private bool collapseNavMenu = true;

private string? NavMenuCssClass => collapseNavMenu ? "collapse" : null;

private void ToggleNavMenu()
{
collapseNavMenu = !collapseNavMenu;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
.navbar-toggler {
background-color: rgba(255, 255, 255, 0.1);
}

.top-row {
min-height: 3.5rem;
background-color: rgba(0,0,0,0.4);
}

.navbar-brand {
font-size: 1.1rem;
}

.bi {
display: inline-block;
position: relative;
width: 1.25rem;
height: 1.25rem;
margin-right: 0.75rem;
top: -1px;
background-size: cover;
}

.bi-house-door-fill-nav-menu {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-house-door-fill' viewBox='0 0 16 16'%3E%3Cpath d='M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5Z'/%3E%3C/svg%3E");
}

.bi-plus-square-fill-nav-menu {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-plus-square-fill' viewBox='0 0 16 16'%3E%3Cpath d='M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z'/%3E%3C/svg%3E");
}

.bi-list-nested-nav-menu {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-list-nested' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M4.5 11.5A.5.5 0 0 1 5 11h10a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 3 7h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 1 3h10a.5.5 0 0 1 0 1H1a.5.5 0 0 1-.5-.5z'/%3E%3C/svg%3E");
}

.nav-item {
font-size: 0.9rem;
padding-bottom: 0.5rem;
}

.nav-item:first-of-type {
padding-top: 1rem;
}

.nav-item:last-of-type {
padding-bottom: 1rem;
}

.nav-item ::deep a {
color: #d7d7d7;
border-radius: 4px;
height: 3rem;
display: flex;
align-items: center;
line-height: 3rem;
}

.nav-item ::deep a.active {
background-color: rgba(255,255,255,0.37);
color: white;
}

.nav-item ::deep a:hover {
background-color: rgba(255,255,255,0.1);
color: white;
}

@media (min-width: 641px) {
.navbar-toggler {
display: none;
}

.collapse {
/* Never collapse the sidebar for wide screens */
display: block;
}

.nav-scrollable {
/* Allow sidebar to scroll for tall menus */
height: calc(100vh - 3.5rem);
overflow-y: auto;
}
}
18 changes: 18 additions & 0 deletions Spreadsheet/BlazorWASMApp/SpreadSheetSample/Pages/Counter.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
@page "/counter"

<PageTitle>Counter</PageTitle>

<h1>Counter</h1>

<p role="status">Current count: @currentCount</p>

<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>

@code {
private int currentCount = 0;

private void IncrementCount()
{
currentCount++;
}
}
17 changes: 17 additions & 0 deletions Spreadsheet/BlazorWASMApp/SpreadSheetSample/Pages/Home.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
@page "/"
@using Syncfusion.Blazor.Spreadsheet

<SfSpreadsheet DataSource="DataSourceBytes">
<SpreadsheetRibbon></SpreadsheetRibbon>
</SfSpreadsheet>

@code {
public byte[] DataSourceBytes { get; set; }

protected override void OnInitialized()
{
// Replace with your base64-encoded Excel file
string base64File = "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";
DataSourceBytes = Convert.FromBase64String(base64File);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
@page "/not-found"
@layout MainLayout

<h3>Not Found</h3>
<p>Sorry, the content you are looking for does not exist.</p>
57 changes: 57 additions & 0 deletions Spreadsheet/BlazorWASMApp/SpreadSheetSample/Pages/Weather.razor
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
@page "/weather"
@inject HttpClient Http

<PageTitle>Weather</PageTitle>

<h1>Weather</h1>

<p>This component demonstrates fetching data from the server.</p>

@if (forecasts == null)
{
<p><em>Loading...</em></p>
}
else
{
<table class="table">
<thead>
<tr>
<th>Date</th>
<th aria-label="Temperature in Celsius">Temp. (C)</th>
<th aria-label="Temperature in Fahrenheit">Temp. (F)</th>
<th>Summary</th>
</tr>
</thead>
<tbody>
@foreach (var forecast in forecasts)
{
<tr>
<td>@forecast.Date.ToShortDateString()</td>
<td>@forecast.TemperatureC</td>
<td>@forecast.TemperatureF</td>
<td>@forecast.Summary</td>
</tr>
}
</tbody>
</table>
}

@code {
private WeatherForecast[]? forecasts;

protected override async Task OnInitializedAsync()
{
forecasts = await Http.GetFromJsonAsync<WeatherForecast[]>("sample-data/weather.json");
}

public class WeatherForecast
{
public DateOnly Date { get; set; }

public int TemperatureC { get; set; }

public string? Summary { get; set; }

public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
}
}
13 changes: 13 additions & 0 deletions Spreadsheet/BlazorWASMApp/SpreadSheetSample/Program.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
using Microsoft.AspNetCore.Components.Web;
using Microsoft.AspNetCore.Components.WebAssembly.Hosting;
using SpreadSheetSample;
using Syncfusion.Blazor;

var builder = WebAssemblyHostBuilder.CreateDefault(args);
builder.RootComponents.Add<App>("#app");
builder.RootComponents.Add<HeadOutlet>("head::after");

builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) });
builder.Services.AddSyncfusionBlazor();

await builder.Build().RunAsync();
Loading
Loading