This is a migrated thread and some comments may be shown as answers.

Change the way negative numbers show

7 Answers 217 Views
NumericTextBox
This is a migrated thread and some comments may be shown as answers.
Bob
Top achievements
Rank 1
Iron
Veteran
Iron
Bob asked on 15 Apr 2021, 08:53 PM

I want negative #'s to show as -9999 not (9999). 

Is there any way to do this?  

I could do it with the Kendo controlsby putting kendo.culture().numberFormat.currency.pattern[0] = "-$n"; in the document.ready function but I can't see to figure out how to do it with Blazor controls.

Thanks.

7 Answers, 1 is accepted

Sort by
0
Marin Bratanov
Telerik team
answered on 16 Apr 2021, 11:47 AM

Hello Bob,

The format in Blazor numeric textbox is determined by the thread culture, you can read more about the behavior of our components with globalization and cultures in the dedicated article: https://docs.telerik.com/blazor-ui/globalization/overview.

So, in the common case, the format will be simply a minus in front of the number.

I am attaching here one localization sample modified to also have a numeric textbox so you can see the behavior when the culture is changed.

Regards,
Marin Bratanov
Progress Telerik

Virtual Classroom, the free self-paced technical training that gets you up to speed with Telerik and Kendo UI products quickly just got a fresh new look + new and improved content including a brand new Blazor course! Check it out at https://learn.telerik.com/.

0
Bob
Top achievements
Rank 1
Iron
Veteran
Iron
answered on 16 Apr 2021, 12:06 PM

I did read that article, but I didn't see anything that said I could change Globalization options, only localization which appears to only be the wording within controls.  However, on that note, I wanted to change the Options in the Confirm Dialog to be "Yes" & "No" instead of "OK" and "Cancel".

I looked that the resx file in the Demos folder like the localization article said but could not find anything in it for the Dialog control.  I have the latest version of controls as well.

I will check out your video and the link you attached and hopefully they will help.

0
Marin Bratanov
Telerik team
answered on 16 Apr 2021, 12:30 PM

Hi Bob,

Try the project, ensure you have set an explicit culture on the threads and see how things go. The numeric textbox basically does a .ToString(Format) and thus .NET generates the string based on the format settings of the culture. You may also want to check if your application overrides the number format.

As for the dialog buttons - you can use localization, the keys for those buttons are "Dialog_Ok" and "Dialog_Cancel". If you do not see them in the messages file in our demos, then the demos you are reviewing are for an older version. You need to make sure to check them out from the 2.23.0 version, the previous ones don't have the dialog component.

It is important to keep in mind that localization is a subset of globalization, just like number and date formats are subsets of globalizing an app.

Regards,
Marin Bratanov
Progress Telerik

Virtual Classroom, the free self-paced technical training that gets you up to speed with Telerik and Kendo UI products quickly just got a fresh new look + new and improved content including a brand new Blazor course! Check it out at https://learn.telerik.com/.

0
Bob
Top achievements
Rank 1
Iron
Veteran
Iron
answered on 16 Apr 2021, 12:57 PM

Sorry, but I don't really understand what you mean by "ensure you have set an explicit culture on the threads"?

I see where you add the localization in the Startup.cs but I don't see anything about Globalization being set anywhere.  

Sorry, I a new to this globalization & localization stuff.

0
Marin Bratanov
Telerik team
answered on 16 Apr 2021, 01:17 PM

Hi Bob,

The localization middleware does that for you in a server-side blazor app, based on the cookie and the controller action that makes it.

You can also explore the WASM sample where the culture setting through a culture chooser UI is much more explicit: https://github.com/telerik/blazor-ui/tree/master/common/localization/ClientLocalizationResx - see this in Program.cs: https://github.com/telerik/blazor-ui/blob/master/common/localization/ClientLocalizationResx/Client/Program.cs#L34-L45

I also recommend you review the MSDN documentation about globalizing Blazor as a first step in this journey:

 

Regards,
Marin Bratanov
Progress Telerik

Тhe web is about to get a bit better! 

The Progress Hack-For-Good Challenge has started. Learn how to enter and make the web a worthier place: https://progress-worthyweb.devpost.com.

0
Bob
Top achievements
Rank 1
Iron
Veteran
Iron
answered on 16 Apr 2021, 03:14 PM

Got the localization working.

For the Globalization, it took me some time, but I finally figured out I had to add the following line in my startup.cs to get it to work when I am formatting the value as "C". 

 

supportedCultures.First().NumberFormat.CurrencyNegativePattern = 1;

(Note, I am only using one culutre, "en-US" so using .First() works just fine for me)

0
Marin Bratanov
Telerik team
answered on 16 Apr 2021, 03:24 PM

Glad to see you have solved this, Bob!

--Marin

Tags
NumericTextBox
Asked by
Bob
Top achievements
Rank 1
Iron
Veteran
Iron
Answers by
Marin Bratanov
Telerik team
Bob
Top achievements
Rank 1
Iron
Veteran
Iron
Share this question
or