dymaptic.GeoBlazor.Core 2.0.1-beta-1

This is a prerelease version of dymaptic.GeoBlazor.Core.
There is a newer version of this package available.
See the version list below for details.
dotnet add package dymaptic.GeoBlazor.Core --version 2.0.1-beta-1                
NuGet\Install-Package dymaptic.GeoBlazor.Core -Version 2.0.1-beta-1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="dymaptic.GeoBlazor.Core" Version="2.0.1-beta-1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add dymaptic.GeoBlazor.Core --version 2.0.1-beta-1                
#r "nuget: dymaptic.GeoBlazor.Core, 2.0.1-beta-1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install dymaptic.GeoBlazor.Core as a Cake Addin
#addin nuget:?package=dymaptic.GeoBlazor.Core&version=2.0.1-beta-1&prerelease

// Install dymaptic.GeoBlazor.Core as a Cake Tool
#tool nuget:?package=dymaptic.GeoBlazor.Core&version=2.0.1-beta-1&prerelease                

GeoBlazor

Home Page

View the live demo site!

Read the Docs

Join our Discord Server!

Build Requirements

For the Asp.NET projects, including the core library, you can run on the latest .NET 6 SDK or .NET 7 SDK.

For the Maui sample project, you need the latest Visual Studio 2022 and/or .NET 7 SDK.

If you have not installed node.js on your system, you will need to download and install it in order for the npm scripts to run. Please select the appropriate installer for your system.

You will need to install Powershell 7 on your machine to run the powershell script as part of the build process. -Complete installation instructions for Powershell [can be found here] (https://learn.microsoft.com/en-us/powershell/scripting/install/installing-powershell?view=powershell-7.2).

Note A reboot is required after installing the above components.

Because GeoBlazor uses an unsigned, local powershell script to copy files in the Sample.Shared project, you need to allow unsigned scripts to be run in Powershell. -The procedure to change the "execution policies" and set them to RemoteSigned are found here: https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_execution_policies?view=powershell-7.2#change-the-execution-policy

Note If you receive an unsigned error even after you set the above execution policy, try setting it again in the older version of PowerShell (the one that comes with Windows).

On the first build, the Core project needs to download a large number of files from npm to node_modules, and then copy them into wwwroot/assets. If this process fails, or you get an error on running the samples of "Cannot load ArcGIS Assets", usually re-building the project will fix the errors.

Projects

dymaptic.GeoBlazor.Core

  • The core logic library

dymaptic.GeoBlazor.Core.Sample.Shared

dymaptic.GeoBlazor.Core.Sample.Server

  • Asp.NET Core Blazor Server application sample
  • dotnet run --project .\samples\dymaptic.GeoBlazor.Core.Sample.Server\dymaptic.GeoBlazor.Core.Sample.Server.csproj
  • Runs on kestrel or via IIS
  • Serves pages via SignalR/Websockets
  • Can be loaded with a usersecrets file to provide the ArcGIS Api Key.

dymaptic.GeoBlazor.Core.Sample.Wasm

  • dotnet run --project .\samples\dymaptic.GeoBlazor.Core.Sample.Wasm\dymaptic.GeoBlazor.Core.Sample.Wasm.csproj
  • Runs Blazor in Web Assembly on the client browser
  • No safe storage for API key, users must input an api key or sign in from the browser

dymaptic.GeoBlazor.Core.Sample.Maui

  • Cross-platform mobile and desktop application
  • Should be run from Visual Studio Preview. Command Line support appears to be limited at this time.
  • Android and Windows versions tested

dymaptic.GeoBlazor.pro (not included in open source repo)

  • Extended application features - coming soon!
  • Please contact info@dymaptic.com to discuss licensing these advanced features!

This project wraps the ArcGIS Javascript API in a Blazor templating framework. It generates a nuget package that can be imported and consumed from any Blazor application, without directly interacting with javascript.

In addition to "hiding" the javascript implementation, the goal is also to make a simple, component-based system for declaring a map and view. For example:

<MapView Longitude="_longitude" Latitude="_latitude" Zoom="11" Style="height: 600px; width: 100%;">
    <Map ArcGISDefaultBasemap="arcgis-topographic">
        <GraphicsLayer>
            <Graphic>
                <Point Longitude="_longitude" Latitude="_latitude"/>
                <SimpleMarkerSymbol Color="@(new MapColor(226, 119, 40))">
                    <Outline Color="@(new MapColor(255, 255, 255))" Width="1"/>
                </SimpleMarkerSymbol>
            </Graphic>
            <Graphic>
                <PolyLine Paths="@_mapPaths"/>
                <SimpleLineSymbol Color="@(new MapColor(226, 119, 40))" Width="2"/>
            </Graphic>
            <Graphic>
                <Polygon Rings="@_mapRings"/>
                <SimpleFillSymbol Color="@(new MapColor(227, 139, 79, 0.8))">
                    <Outline Color="@(new MapColor(255, 255, 255))" Width="1"/>
                </SimpleFillSymbol>
                <Attributes Name="This is a Title" Description="And a Description"/>
                <PopupTemplate Title="{Name}" Content="{Description}"/>
            </Graphic>
        </GraphicsLayer>
    </Map>
</MapView>

for a 2D map with a default ArcGIS basemap, or

<SceneView Longitude="_longitude" Latitude="_latitude" Zoom="11" Style="height: 600px; width: 100%;" ZIndex="2000" Tilt="76">
    <Map Ground="world-elevation">
        <Basemap>
            <PortalItem Id="f35ef07c9ed24020aadd65c8a65d3754" />
        </Basemap>
        <GraphicsLayer>            <Graphic>
                <Point Longitude="_longitude" Latitude="_latitude"/>
                <SimpleMarkerSymbol Color="@(new MapColor(226, 119, 40))">
                    <Outline Color="@(new MapColor(255, 255, 255))" Width="1"/>
                </SimpleMarkerSymbol>
            </Graphic>
            <Graphic>
                <PolyLine Paths="@_mapPaths"/>
                <SimpleLineSymbol Color="@(new MapColor(226, 119, 40))" Width="2"/>
            </Graphic>
            <Graphic>
                <Polygon Rings="@_mapRings"/>
                <SimpleFillSymbol Color="@(new MapColor(227, 139, 79, 0.8))">
                    <Outline Color="@(new MapColor(255, 255, 255))" Width="1"/>
                </SimpleFillSymbol>
                <Attributes Name="This is a Title" Description="And a Description"/>
                <PopupTemplate Title="{Name}" Content="{Description}"/>
            </Graphic>
        </GraphicsLayer>
    </Map>
</SceneView>

for a 3D map with a basemap loaded from a PortalId.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on dymaptic.GeoBlazor.Core:

Package Downloads
dymaptic.GeoBlazor.Pro

GeoBlazor is a GIS Component Library and SDK for building interactive maps in Blazor, powered by ArcGIS. For more information, visit https://www.geoblazor.com or contact dymaptic at geoblazor@dymaptic.com

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on dymaptic.GeoBlazor.Core:

Repository Stars
dymaptic/GeoBlazor
Core Components for the Dymaptic GeoBlazor Library
Version Downloads Last updated
3.1.1 1,099 8/15/2024
3.1.0 373 8/1/2024
3.0.3-beta-4 153 7/20/2024
3.0.3-beta-3 210 6/27/2024
3.0.3-beta-2 132 6/27/2024
3.0.3-beta-1 145 6/27/2024
3.0.2 1,332 5/8/2024
3.0.2-beta-11 286 4/26/2024
3.0.1 1,365 3/26/2024
3.0.0 303 3/23/2024 3.0.0 is deprecated because it has critical bugs.
3.0.0-rc.2 147 3/9/2024
3.0.0-rc.1 103 3/6/2024
3.0.0-beta-95 333 2/24/2024
2.5.3.2 5,168 2/11/2024
2.5.3.1 303 2/10/2024 2.5.3.1 is deprecated because it has critical bugs.
2.5.3 338 2/10/2024 2.5.3 is deprecated because it has critical bugs.
2.5.2 1,754 12/20/2023
2.5.1 735 12/13/2023
2.5.0 1,086 11/26/2023
2.4.1-beta-1 1,063 10/19/2023
2.4.0 2,619 10/12/2023
2.3.3 2,192 9/14/2023
2.3.2 1,284 9/12/2023
2.3.1-beta-1 1,582 8/18/2023
2.3.0 2,126 8/9/2023
2.3.0-beta-1 1,683 8/2/2023
2.2.1 2,958 7/7/2023
2.2.1-beta-1.1 156 6/16/2023
2.2.0 3,070 6/2/2023
2.2.0-beta-5 1,797 5/28/2023
2.2.0-beta-4 2,227 5/23/2023
2.2.0-beta-3 755 5/20/2023
2.2.0-beta-2 783 5/20/2023
2.2.0-beta-1 1,676 5/13/2023
2.1.0 5,528 4/18/2023
2.1.0-beta-1 1,767 4/16/2023
2.0.2-beta-2 2,050 4/2/2023
2.0.2-beta-1 2,046 4/1/2023
2.0.1 2,274 3/18/2023
2.0.1-beta-3 1,685 3/5/2023
2.0.1-beta-2 1,708 3/4/2023
2.0.1-beta-1 1,951 3/4/2023
2.0.0 2,575 2/28/2023
2.0.0-beta-9 1,780 2/24/2023
2.0.0-beta-8 1,960 2/19/2023
2.0.0-beta-7 1,661 2/19/2023
2.0.0-beta-6 1,987 2/15/2023
2.0.0-beta-5 1,741 2/15/2023
2.0.0-beta-4 1,824 2/11/2023
2.0.0-beta-3 1,905 2/9/2023
2.0.0-beta-2 1,715 2/7/2023
2.0.0-beta-11 1,846 2/25/2023
2.0.0-beta-10 1,640 2/25/2023
2.0.0-beta-1 1,792 2/5/2023
1.2.0 2,999 11/13/2022
1.1.1 1,373 10/20/2022
1.1.0 1,204 10/8/2022