Replies: 62 comments 214 replies
-
MAUI is free open source project. Calling it SCAM because it has some bugs is ridicoulus. The team is working hard to fix issues one by one, but it takes time. It is still a new platform that hasn't matured yet. It's up to debate whether it should have been marked production ready so early in the process and whether enough resources were comitted to the developement, but it certainly isn't SCAM and I'm sure it will become really great technology by .NET 8 release. |
Beta Was this translation helpful? Give feedback.
-
@Sebosek I completely agree with the sentiment of your post and support your right to vent at the substantial issues that we have with .NET Maui. I vent on a daily basis in fact! |
Beta Was this translation helpful? Give feedback.
-
I don't think profanity is doing anyone a service but I do understand there's a lot of frustration pent up and certainly some miscommunication. Let's see if I can present my view in a comprehensive way. Me & my 2 colleagues we're coming from a former non-trivial Xamarin.Forms app. We have lots of Html&Javascripts to interact with (Hello HybridWebViewRenderer), need to support background-syncing of resources, need to display several documents in a tabbed view, need to switch between list- & grid-representations on-the-fly (Lots of DataTemplateSelectors) and much more... Gotcha #1: End of life for XamarinMay 2024 sounds like a lot of time is still left but that is only if you are content with the current target platforms ("Android 13 and Xcode 14 SDKs (iOS and iPadOS 16, macOS 13) will be the final versions Xamarin will target"). If iOS 17 or Android 14 break compatibility with Xamarin.Forms 5 for whatever reason, then good luck requesting a new service release. Gotcha #2: "production ready"?Ok, that one has been pointed out to death so let's summarize: Gotcha #3: Migration best practices?As I mentioned: We had/have a pretty complex app (Personal opinion: Anything more complex than a ToDo-app in Xamarin or Maui requires deviation from the standard templates) and couldn't really rely on any migration tools. Gotcha #4: RegressionsWith .Net 7 we finally felt like the framework was getting better. We had our own HybridWebViewHandler ready, got lots of the views to display something meaningful. Gotcha #5: So fix it yourself, you nagger. It's open source!Excellent point! And that I haven't succeeded at this is likely due to my lazyiness and/or incompetence. Gotcha #6: Dotnet... beta?From the recent PullRequests and monitoring the Service Releases it seems like .Net 7 is already considered stale and all improvements happen on .Net 8. In hindsight: I experienced a lot of helpful remarks in issues, discussions, blog posts, etc. and I see skillful people commiting to the project! |
Beta Was this translation helpful? Give feedback.
-
I don't consider MAUI to be a scam, but I am a little disappointed that after three years since the blog post (https://devblogs.microsoft.com/dotnet/introducing-net-multi-platform-app-ui/#mvu), there is still no official support for MVU or Comet framework(https://github.com/dotnet/Comet). |
Beta Was this translation helpful? Give feedback.
-
I agree MAUI doesn't fit the definition of a scam, but I do feel for the OP as our team has been in the same boat. Whilst the framework is financially free, you pay for it with your time - either as an individual or as a business. The reason many dev teams use a cross platform tool is to save time, especially those of us who are heavily invested in the .NET ecosystem. Having inaccurate or confusing statements from the project maintainers, bugs etc. can make people feel robbed of that time. Our team are in the late stages of porting a non-trivial Xamarin app over and overall I'd say MAUI works, and the fact it works at all is nothing short of a miracle. I dread to think of the complexity and number of man-hours that have gone into the glue layer between the native platform APIs and .NET and it's a feat of engineering they've got it working as well as they have. Despite my own complaints it has still saved our team countless hours we would've spent battling with native tooling and keeping multiple app versions at feature parity. That said, they did initially promote it as something it was not, which was much a product much less flawed than it actually is. This perception has led to misplaced expectation from developers and in turn lots of frustration, but I'd ask anyone reading this to stick with it as what I'm hearing more recently seems to be the right message. |
Beta Was this translation helpful? Give feedback.
-
I'm sorry for your experience. I've developed one app in Maui Blazor so I didn't encounter so many issues even tho I agree it's a struggle. I feel lucky to have witness this so early on in my career. |
Beta Was this translation helpful? Give feedback.
-
It's not a scam, but it is an absolute shambles. It wouldn't be so bad if there was some kind of response or accountability from Microsoft, but it's like they are all asleep at the wheel, and nobody is around to wake them. |
Beta Was this translation helpful? Give feedback.
-
Q&A at Build 2023: https://www.youtube.com/watch?v=_IxzKLFNMWA |
Beta Was this translation helpful? Give feedback.
-
I totally understand your feelings and frustrations because currently MAUI does have a lot of bugs that need to be fixed before it can be really used in the production. IMO the current quality of MAUI doesn't meet the bar of "production-ready". It may suit for demo apps and prototypes but once you start to put it in real use, you will encounter endless issues including but not limited to memory leaking, binding bugs, slowness (though it may be due to the bad performance of mono and mono-aot), and AOT-related (especially while using AOT with LLVM, which is almost unusable) issues. It is also why I haven't use MAUI in my apps but instead choosing Avalonia or Xamarin.Forms. Microsoft really shouldn't have rushed a GA version of MAUI instead of baking it until the real mature. I even haven't mentioned about MVU/Comet because there are just too many fundamental issues before we can start to talk about patterns and features on a higher level. While the quality of MAUI does become better and better every year, so I would like to expect the next year MAUI in .NET 8 can finally meet the production-ready bar for extensive app development. |
Beta Was this translation helpful? Give feedback.
-
What I want to say is that no matter how good the tools are, there are projects that are not suitable. No matter how bad the tool is, there is a suitable position. Choose to use it, but not blindly. It is hoped that maui will speed up the repair speed, and at the same time, better optimization, blooming sunshine. |
Beta Was this translation helpful? Give feedback.
-
I'm not sure why all the complaints with Maui. I've been using Xamarin since it first appeared over a decade ago and yes, after MS took it over the path got a little more rocky with each iteration. But having developed over 45 apps/platforms since the launch of Xamarin over the last decade+ (ios/android native, forms, and 3 new ones in Maui set to launch over the next 2 months), the biggest thing I've found with devs having issues is because many apps are "over-engineered". What I've seen is they try to throw in every code structure and methodology into every component of the app. Believe it or not, you can create an app that has some components that use MVVM and some that don't. Not every page needs a view model, dependency injection is great but if you don't plan it ahead it will be painful to implement properly (hence all those memory leaks everyone complains about). It's ok to let the back-end do some of the work (servers were designed to do the heavy lifting so the app doesn't need all the biz rules and algorithms inside). Sometimes you don't need layered services (save the "I" service implementations for another day - maybe you don't need the structure). Yes, MAUI has issues but so far, I've been able to work through every issue I've had with it in some way or another and not experiencing the many complaints that everyone is seeing. My biggest recommendation with Maui now is that before writing a single line of code, take a good look at the structure, architecture, and pre-plan ahead. Because as devs, once we start running with the code it gets hard for us to change direction. I'm guilty of this and have learned over the last 10 years that my best dev work comes when I've 80% planning and 20% coding. I wish it was something they taught in these bootcamps, coding classes, and videos. But they focus purely on the code aspect and functionality versus the "how", and "why" of doing something. So is MAUI a scam? No, not in my opinion. Does it take some work to make it "work"? Well, yes, start the coding with understanding what needs to be built and then answering the question "what's the best way to build it?" |
Beta Was this translation helpful? Give feedback.
-
A lot of features inside MAUI is tricky to use, for example the point of providing a bunch different component out of the box is for people not having to implement the wheels based on positions and dimension on screen and drawing the UI and handling input events themselves, but if you can't put a StackLayout Inside a ScrollLayout or things will break or many other situations that we are familiar with that's a mine field to walk through it is kinda counter productive. It's ok to provide options, but the way it's done was causing problem, look at the web you can put img in div or style the img directly nothing would go wrong you can put div in img too |
Beta Was this translation helpful? Give feedback.
-
|
Beta Was this translation helpful? Give feedback.
-
Calling it a scam is not appropriate. But I agree that it is still not production ready. And that Microsoft should have dedicated more development resources to it. Feels like people high up in Microsoft don't understand that one of their key assets is superior developer tools and technologies. Or they are under the delusion that "Blazor" and "Maui Blazor" means they have an adequate response to ReactJS/ReactNative and to Flutter. Nope. Personally, I pulled my current client out of both Maui and Xamarin Forms. Even though I pray that Maui eventually manages to become robust. We rolled our own UI, on top of Xamarin Native (will switch to .Net 8 cross-platform at some point). Similar to Uno Platform, AvaloniaUI, and Unity 3D, not to mention Flutter, we don't attempt to map to native controls on each platform. That way lies madness. SkiaSharp FTW. |
Beta Was this translation helpful? Give feedback.
-
Could not agree more, it's a shitty framework. It does not even properly check audio privileges, it simply relies on the OS (for iOS). What I've encountered so far does not display any kind of capacity for mid to enterprise level applications. It's basically Xamarin, which was shitty as well. I cannot understand why would a company like Microsoft would want to deal with the same problems even after the failure of Xamarin. MAUI still uses Xamarin libraries which in itself proves the stability will never arrive to MAUI. I'm sad that they do not choose a technology similar to Flutter. Even Microsoft has a lot of things to learn. I hate MAUI, would never suggest it, try to use Flutter which is far better on all aspects. |
Beta Was this translation helpful? Give feedback.
-
My problem with using HTML over native widgets is;
There are massive advantages to XAML, which was designed for application front ends from the ground up. XAML however is just a markup language, its real power comes from the tools that support it. WPF is evidence of just how well this can work as WPF is absolutely fantastic - Microsoft did an amazing job on WPF and on the whole it was a huge improvement over WinForms and pretty much everything else at the time. The problem with MAUI is they have not got the tooling into a place where developers can work as cleanly as they can with something like WPF, which causes the dev loop to be extremely long and the runtime is full of bugs partly because they've tried to overgeneralise things without taking the time to fully take into account each platforms idiosyncrasies. Adding yet more platforms as part of the Xamarin -> MAUI migration has just made this worse. |
Beta Was this translation helpful? Give feedback.
-
There are also massive disadvantages to XAML, like it being a whole new thing to work or the fact that it incentivizes enormous ammounts of data sharing and sticking with things like MVVM instead of allowing the construction of dynamic and interactive UI's. For anything but a corporate software it is a pain to work with. |
Beta Was this translation helpful? Give feedback.
-
Does Microsoft use MAUI in any of its products? |
Beta Was this translation helpful? Give feedback.
-
I just want to say that MAUI + Blazor is not bad. |
Beta Was this translation helpful? Give feedback.
-
maui is the best 👍 |
Beta Was this translation helpful? Give feedback.
-
@davidortinau Is it maybe time to close this discussion? It keeps getting pushed to the top without any real new insights. |
Beta Was this translation helpful? Give feedback.
-
Before this discussion gets closed, I would like to add that my experience with Maui has been pleasant and I really like it. I think with .Net 8, things have been lot better. Last week I launched my app "Notezilla" successfully on both Play Store and App Store. Thanks to the generous community. I hope Microsoft keeps the same attitude and improves WinUI 3 too at much faster rate. |
Beta Was this translation helpful? Give feedback.
-
I'm pleased to see reports that our efforts and investments are recognized, and success is being achieved using .NET MAUI. I'm closing this thread as it seems to have run its course. We welcome constructive criticism as it is often the best feedback for guiding our future investments. Please do continue to share both reports with us, and keep in mind the https://dotnetfoundation.org/about/policies/code-of-conduct. |
Beta Was this translation helpful? Give feedback.
-
I agree, apparently for Maui I need to completely rewrite my apps from almost scratch. I am also very unhappy about this. Why can't Microsoft learn from Toyota: continuous improvement, not massive changes every couple years. |
Beta Was this translation helpful? Give feedback.
-
I'm very confused as to why Microsoft invests in cross-platform app development technologies. They can just focus on their own products and leave supporting other platforms to the community/responsible party. The only thing that makes sense to make cross-platform is .NET. Why not focus on WinUI for Windows based devices and Blazor for browser-based dev? The time, cost, and energy invested in these technologies is too much. If someone wants to develop for macOS or iOS, they can simply use SwiftUI or something else. If someone wants to develop for Android, they can use the existing ecosystem that's battle-tested and already works. Why re-invent the wheel? Why must everything be cross-platform? Apple won't do this because they know it's a lot of work to support these changing technologies. They merely focus on their own platforms, their own toolkits, and their own language. Consequentially, they have the most coherent development ecosystem that looks good, optimized, and very much stable. They only need to worry about their own technologies. Microsoft does it all. Jack of all trades and master of none. Excess of everything is bad. The worse thing is that Microsoft won't even use these technologies themselves, which leads to "LACK OF TRUST". |
Beta Was this translation helpful? Give feedback.
-
I think probably want to check your OS stats
Sent from Outlook for Android<https://aka.ms/AAb9ysg>
…________________________________
From: Ivan Todorov ***@***.***>
Sent: Tuesday, December 24, 2024 2:09:29 PM
To: dotnet/maui ***@***.***>
Cc: Chris Owens ***@***.***>; Comment ***@***.***>
Subject: Re: [dotnet/maui] MAUI is just a SCAM (Discussion #15203)
I believe the reason why Microsoft does that is pretty obvious - to lure as much developers as possible to their ecosystem. We are no longer in the 90s, so not everything is just PCs with Windows pre-installed. In fact, Windows is no longer the most used operating system, and the PC is no longer the most widely used hardware. Simply put, to stay relevant, they have no other choice, but to make cross-platform solutions.
Currently, I am working on a software project that requires both Windows and Mac support as a bare minimum, plus Android and iOS for the lightweight mobile version. The users demand it, so we have no other choice, but to give them what they want. Having everything implemented in C# can be a huge time saver - we have about 90% code reuse. Had we chosen to go for the platform-specific route, we would have to use C# on Windows, Swift on Mac and iOS and Java on Android. That would mean almost zero code reuse. In practice, we would have to implement and maintain four different products with the same functionality, using four different technology stacks, at four times the cost.
Without going into much detail, web application is not suitable for this type of project. It has to be a native application, having access to all the features available on the target platform. That's why we keep .NET MAUI in our radar, but currently it is too unstable and lacks some essential features to be of any use to us.
—
Reply to this email directly, view it on GitHub<#15203 (reply in thread)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AJTUAXWOHEIWKOMUURQP6UT2HFTJTAVCNFSM6AAAAAAYKAXLCSVHI2DSMVQWIX3LMV43URDJONRXK43TNFXW4Q3PNVWWK3TUHMYTCNRVHA2DQMA>.
You are receiving this because you commented.Message ID: ***@***.***>
|
Beta Was this translation helpful? Give feedback.
-
We have developed two Maui apps for customers (both in the app and play store). One has about 11k installations, the other almost 50k. The first is using Maui "classic". It works fine although I have to say it´s sometimes hard to use Maui "classic" because of bugs and performance problems. The other app is using Maui Hybrid with blazor. This is much easier and the app size is - in our case - a lot smaller. Blazor is very easy to use and we had a very smooth development experience. We did a web app as well and could resuse 90% of the code. If I had to choose between "classic" and blazor for the next project, I would select Maui hybrid with blazor for sure. So, in the end, a tool (framework) is as good as you are using it. |
Beta Was this translation helpful? Give feedback.
-
For what its worth there are alternatives to MAUI - suggesting switching to react "native" or any other sh!tty JS framework is not the solution. For those happy w/ MAUI - rockon! For those who need a literal alternative using C# / XAML check out Avalonia and the UNO Platform. JS pedlars need to stay in JS land. Just my 2 cents. |
Beta Was this translation helpful? Give feedback.
-
For someone that has used xamarin, maui, blazor and flutter; I am definitely not giving Maui's UI framework a second chance. With all its mirage of issues, the only reason we still use Maui at all are its platform and device abstractions and integrations, not for its UI. Our Maui app is now ported to blazor hybrid and its just so much better than the development workflow of Maui xml and deterministic. What I would have loved so much though is a way to use razor beautiful syntax against flutter widgets (which is becoming my go-to platform now), perhaps some kinds of bindings like @SteveSandersonMS demonstrated way back. BTW, does anyone have access to the repo @SteveSandersonMS used? I'd like to gain some insight into how he did that. |
Beta Was this translation helpful? Give feedback.
-
I tried Dotnet MAUI in version 6 for the first time, but back then I decided to go back and backport back the application in Xamarin.Forms. I've released the app in Xamarin, does the app suffer from the fact it was written using the Xamarin.Forms? No. Not at all. Sometimes it only required more typing, because I'm used to relying on the dependency injection and writing unit tests and Xamarin.Form is full of static calls, so I have to wrap it.
A little bit of background about myself, I'm a contractor, working with from small fintech startups to global tech companies and banks, but from time to time I'm helping non-profit organizations for pro-bono. I've worked on several such projects, usually for a couple of months, and then a little bit of maintenance. I've developed 2 apps in Xamarin.Forms and one React Native. The React Native base was the bigger so far. For the current project, I've decided to give a shot MAUI for the second time. I did a prototype, to verify that the required features are supported (Lottie animations, local notifications, database, ...). Sure, my prototypes worked, it wasn't perfect, but it somehow worked (the first warning sign, #14911), so I prepared CI/CD for the project, agreed with the client, and finally started working on implementation.
The application is very simple, with a very simple design.
Regarding the custom navigation, I was a little bit worried, and after reading the documentation about Shell navigation I got the feeling like, it would be quite problematic to use it with my navigation, so I gave it a day and a half and create my own including the animation, it worked like a charm until I hit the wall for the first time. The data binding between View and ViewModel does work only for buttons, using gesture recognizers it just does not work, #15147.
Along the way, I also found that the border control is broken on Android and it renders 1px space around, so the green background is visible on edges, but it was already reported and planned for a fix in version 8, a second warning sign.
I tried a different approach, using the Shell. It "worked", but the animation does not. I should describe the animation, once you tap on the icon, the active page (the one with the green color and title in the menu) becomes blackish and slowly hide the text (text width becomes 0) on changing the page and the icon for a new active page becomes green and shows the title. The animations were broken by changing the page. You can't put in the shell something other than page content, so every page has to have the same menu control. Bummer.
What other options do I have... After some research, I found, that some ppl are using Carousal View and I was like: "Oh, why I haven't occurred to me before." I was a little bit ashamed of myself.
So, I created the DataTemplateSelector, and prepare views, the menu worked, and the animations worked, but the data binding in views are completely broken. Even the controls aren't bound to the view model properties, it is just completely broken. Kick into the face.
I'm losing hope, but let's it take from a different angle, let's create an observable collection with content views and render them in the content view in the carousal view, similarly for the very first attempt. IllegalStateException. Kict into the nuts.
Let's use the Content presented, exactly like the very first attempt. IllegalStateException. What the hell?!
I'm giving up.
💩
Beta Was this translation helpful? Give feedback.
All reactions