Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/BlazorFluentUI/BlazorFluentUI

Port of FluentUI/Office Fabric React components and style to Blazor
https://github.com/BlazorFluentUI/BlazorFluentUI

blazor csharp wasm

Last synced: 3 months ago
JSON representation

Port of FluentUI/Office Fabric React components and style to Blazor

Awesome Lists containing this project

README

        

# Anouncement
Although we have created a quite complete port of the Fluent UI React library, it has become clear that it is impossible for us to keep up with the changes that Microsoft and the community are making there. That, combined with the fact that we have only a few people working on the code (in their spare time mostly), has made us decide that as of now we will be switching to maintenace mode for the BlazorFluentUI library.

### What does this mean?
We will not be adding any new functionality and bug fixing will be minimal.

### Does this mean I should not use BlazorFluentUI anymore?
That is up to you. The functionality and features that are available will stay available. We have released a ~V6~ V8 version, running on .NET 6, 7 and 8. This means you can still use the library **in it's current form** until at least November 10, 2026 (when .NET 8 support will end).

### What is my alternative?
Microsoft has released V1.0 of a Blazor wrapper (https://github.com/microsoft/fluentui-blazor) for their Fluent UI Web Components library based on standard Web Components technology (https://github.com/microsoft/fluentui/blob/master/packages/web-components/README.md) which is an implementation of their FAST framework (https://www.fast.design/). We are in close contact with the Microsoft team, leveraging our knowledge gained with building BlazorFluentUI and are already actively contributing to the repository. The are not aiming to match what you get with Fluent UI React today. Rather, they are building to the latest version of Fluent as seen in Windows 11. A demo and documentation site for the Fluent UI Blazor component library can be found at https://www.fluentui-blazor.net.

# BlazorFluentUI
Port of Fluent UI React components and style (formerly Office Fabric) to Blazor

## Blazor Webassembly Demo
https://www.blazorfluentui.net/

## Blazor Server Demo
https://blazorfluentui.azurewebsites.net/ (Older version!)

## How to use the library
[Installation](https://github.com/BlazorFluentUI/BlazorFluentUI/wiki/Installation) \
How To Use: [Blazor Webassembly](https://github.com/BlazorFluentUI/BlazorFluentUI/wiki/How-To-Use:-Blazor-WebAssembly) \
How To Use: [Blazor Server](https://github.com/BlazorFluentUI/BlazorFluentUI/wiki/How-To-Use:-Blazor-Server) \
[Theming](https://github.com/BlazorFluentUI/BlazorFluentUI/wiki/Theming---defaults-and-custom)

## Revision history
### V8.0
Packes compiled with .NET 8 SDK only. No other changes have been made.

### V6.0
Using the .NET 6 released packages now.

### V5.7
**Breaking Changes!**

Icons are now sourced from the MIT licensed FluentUI Icons repo (https://github.com/microsoft/fluentui-system-icons). These are embedded within the CoreComponents project. Icon names are now all "snakecase" (lowercase with underscores). Some of the icon names are completely different. You can either visit the repo linked or see this demo's Icons page. `FontSize` is an additional option for `Icon` which is largely irrelevant unless you modify the size using css. However, `Filled` is a unique option that chooses the filled version of the icon, if it exists. You no longer need to reference the fabric.min.css file in your index.html page.

### V5.6
IDropdownOption (and therefore DropdownOption) is extended to implement IComparable. This makes it possible to sort on selected dropdown values in a details list.

### V5.5
- Added parameter `DropdownHeight`to limit the height of the dropdownlist. See first sample on https://www.blazorfluentui.net/dropdownPage for usage (also showing DropdownWidth)

### V5.4
- DetailsList and DetailsListAuto speed vastly improved
- Callout no longer tracking references in script. No more double clicking needed for opening Dropdown, etc.

### V5.3
- `TextFieldNumber` is renamed to `NumericTextField`
- `MaskedTextFiled` is now available as a **BETA** component. See https://www.blazorfluentui.net/MaskedTextFieldPage for examples

### V5.2
- Library is now using JavaScript isolation (see https://docs.microsoft.com/en-us/aspnet/core/blazor/call-javascript-from-dotnet?view=aspnetcore-5.0#blazor-javascript-isolation-and-object-references). No longer needed to reference the scripts in your `_Host.cshtml` / `index.html`! (with exception of the still experimental RichTextEditor script and acompanying Quill library). Blazor Server in .NET 5.0 no longer supports IE11/Legacy edge so neither does the demo.

### V5.1
- Add editable column for `DetailsList, DetailsListAuto`
- Add new component `TextFieldNumber` (will be renamed to NumberTextField soon), based on `TextField`. Supports `int, long, short, float, double and decimal`.
See https://www.blazorfluentui.net/TextFieldNumberPage for examples

## Breaking Changes for major releases
### V5.0: Renaming and demo revamp
We dropped the `BFU` prefix from all the component- and project names. Also, all components are now bundled in only two packages (to make a distinction between components dependant on DynamicData package an those who are not).

In cases where renaming would lead to collisions with already existing Blazor components or .NET classes, we placed those components in seperate namespace (which you need to include explicitly) and/or you need to use the full name of the component (so including the namespace) in your .razor files.

Both changes were made to align the library closer to the Fluent UI React environment. Also the codebase is not so cluttered with 'BFU' anymore.

The demo sites have been given a lot of attention and look a lot better now (more in line with Fluent UI Rect docs).

### Breaking Changes for v4.0
Library is now running on .NET 5

#### List, DetailsList, GroupedList
You will now have to define your list's container separately from the list component. Pick a `

` or other container element and apply the `data-is-scrollable` to it. You'll also have to style it appropriately for your page. (For example, add `overflow-y:auto;height:100%;` or something similar.) You do **not** have to place your list component as a *direct* descendant of this container. If you fail to place the `data-is-scrollable` tag, then the component will traverse the nodetree to find the first container element that has `overflow-y:auto;` set.

You also have to define `GetKey` for your list component. This is a selector for your items to tell the component how to uniquely identify each item.

A big change is that `OnItemInvoked` will only work when `SelectionMode` is set to `None`. If you need Selection active and the invoke item function to work at the same time, you can attach an event handler to the `Selection.OnSelelectionChanged` event or subscribe to the `SelectionChanged` observable.

#### Removed BFUGlobalCS, BFUStylePreloader, IHasPreloadableGlobalStyle
These components and interfaces must be removed as they no longer function within this library. Switch to using CSS isolation with your razor components instead. `BFULocalCS` is still present and encouraged for dynamic styling that requires flexibility. (Using the style attribute on an element makes it difficult for users to override the style.)

If you need to reference the theme from a css file, you can reference the global css variable instead. For example, where before you would get a white color in C# as `Theme.Palette.White`, now you will write in css, `var(--palette-White)`. Css global variables always start with two dashes and a lowercase name. Instead of a dot, use a dash followed by capitalized names.

## Info
There are no MergeStyles in this port. It's just each control packaged into its own project so you can limit what gets added to your Blazor project.

## Dev Nuget Packages
On each commit new dev NuGet packages will be created automatically. To access those, add a new Package Source to Visual Studio or your project with the following URL:

```
https://pkgs.dev.azure.com/blazor-fluentui/5355f597-190a-4424-83da-cd89cd362a24/_packaging/DevChannelV5/nuget/v3/index.json
```
For a more detailed tutorial, head over to our [Public Feed](https://dev.azure.com/blazor-fluentui/Blazor%20FluentUI/_packaging?_a=feed&feed=DevChannelV5), click on "Connect To Feed" and select the platform.

## Telegram dev channel
https://t.me/joinchat/TuHGR8AZmYe1SKlH