-
Notifications
You must be signed in to change notification settings - Fork 10.1k
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
Blazor form component InputSelect should support binding of type Guid #9939
Comments
I have a similar problem using Blazor server-side. I am using integers ID and binding InputSelect to that.
|
@rynowak was this one of the issues your TypeConverter work fixed? |
That is unrelated. |
Guid (or UUID) is used by every modern web app on the face of the planet. It should have first class support everywhere it's possible to use it. Currently this has to be worked around by adding redundant properties to your model and explicitly invoking Convert on the getter and setter every time you want to use InputSelect based on an object's Guid. `
` This is frustrating and tedious. Not Blazing! |
It is a shame that the fix (#17126) was not finished. |
I am really curious about the thought process behind only supporting string and enum. It is obvious to me that the integer types, guid and their nullable versions should also be supported |
any update on this? |
Our company managed to solve this by remaking the entire form system. (Just like those folks over at Syncfu**** / Teler** / DevExp**** with their closed source and proprietary custom components) I'll just drop this source code, hopefully can be an inspiration for whoever tackling this issue. using System;
using System.Collections.Generic;
using System.Text;
namespace Accelist.BlazorRAD
{
/// <summary>
/// Contains methods to convert string to most CLR basic types.
/// </summary>
public static class PowerConvert
{
/// <summary>
/// Converts a string into an typed object.
/// </summary>
/// <param name="t"></param>
/// <param name="value"></param>
/// <returns></returns>
public static object FromString(Type t, string value)
{
if (string.IsNullOrEmpty(value))
{
if (t.IsValueType)
{
return Activator.CreateInstance(t);
}
else
{
return null;
}
}
if (t == typeof(string))
{
return value;
}
var t2 = Nullable.GetUnderlyingType(t);
if (t2 != null)
{
t = t2;
}
if (t == typeof(Guid))
{
return Guid.Parse(value);
}
// DateTime is IConvertible so no manual conversion is required
if (t == typeof(DateTimeOffset))
{
return DateTimeOffset.Parse(value);
}
if (t == typeof(TimeSpan))
{
// DateTimeOffset can parse HH:MM:SS but TimeSpan cannot parse ISO 8601!
var dt = DateTimeOffset.Parse(value);
return new TimeSpan(dt.Hour, dt.Minute, dt.Second);
}
// https://docs.microsoft.com/en-us/dotnet/api/system.iconvertible?view=netcore-3.1
// https://docs.microsoft.com/en-us/dotnet/api/system.convert.changetype?view=netcore-3.1
return Convert.ChangeType(value, t);
}
/// <summary>
/// Converts a string into an typed object.
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="value"></param>
/// <returns></returns>
public static T FromString<T>(string value)
{
return (T)FromString(typeof(T), value);
}
}
} /// <summary>
/// Converts the property value to string.
/// If the property type is <see cref="DateTime"/> or <see cref="DateTimeOffset"/>, convert it into ISO 8601 format.
/// If the property type is <see cref="DateTime"/> with unknown time zone, treat it as UTC Time Zone.
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public string GetValueAsString(object model)
{
var value = Property.GetValue(model);
if (value is DateTime dt)
{
if (dt.Kind == DateTimeKind.Unspecified)
{
dt = DateTime.SpecifyKind(dt, DateTimeKind.Utc);
}
return dt.ToString("o");
}
if (value is DateTimeOffset dto)
{
return dto.ToString("o");
}
return value?.ToString();
} Basically what happens is that because most basic HTML form inputs for Blazor works just fine when used with
That way, whenever the input is mutated from the HTML, it can be converted into the desired data type via On the other way, the value of the actual data type chosen by the developer (For example: GUID, integer, etc.) should first be converted into This way, Blazor input controls can be used with any basic data types. |
Is there any update on this? |
Ran into this today when starting (and subsequently abandoning) our plan to replace our MVC forms with Blazor Components. It seems someone lied to us and said that Blazor was production-ready. |
@valuator18, for info Blazor is definitely production ready, we've have a large server-side Blazor app running in production for a few months now. There are several ways around this particular issue (some discussed above) and third party controls that have this functionality. Alternatively you can just declare a derived property that converts your Guid property to a string and bind to that instead. |
@danroth27 It seems that Guids and integers should have been supported from the onset. Now I have to tell anyone I recommend Blazor to about this issue which should have been baked in from the start. I feel like Blazor is not production-ready with such issues. |
@ryanelian I also had to implement a workaround to make it work with GUID. I would really appreciate it being possible to link Guid-type data. I hope a solution will be part of 5.0 |
Is your feature request related to a problem? Yes.
Following code does not work if binding Type is Guid. The runtime error in browser console is `InputSelect does not support the type Guid"
Describe the solution you'd like
InputSelect should support binding for type Guid.
Describe alternatives you've considered
I have to create custom MyInputSelect on top of InputSelect which supports Guid.
Additional context
Asp.Net Core 3 Preview 4
Browser:
Chrome @version:73
The text was updated successfully, but these errors were encountered: