Dashboard 2 Migration using AI?

I can try.

As I interpreted Bart's comments, he is concerned about the growing backlog of github issues and he feels he is taking a disproportionate share of resolving them.
I don't doubt that he is right - a change appears in the released version; who did the work is not transparent.
Certainly I have never tackled any of those issues, I have a github account but no knowledge.
I hope Bart continues to contribute.

I think however that his assertion that zero people are helping does not take into account some valuable contributions:
Several discussions in "Share your projects" and other categories demonstrate creative ways to use the dashboard, including templates which can be used as easily as any widget.
There are several contrib nodes.
Any discussion here which sees a problem resolved or a clarification contributes to the project.

Bart already is, he has been incredibly generous with his time to help push Dashboard forward, but we need dozens of contributors (and more) even just tackling small issues. It all helps move the project forward.

It's a challenge though, that I've also seen with Node-RED, the community are not software engineers (that's why theyā€™re using the open source low-code tools in the first place generally), so it then means the community doesnā€™t have the skillset to contribute to the projects themselves. Any help is genuinely appreciated though, and ideas on how we can encourage more contributions are very welcome too

I'm sure, having known Bart for several years, that he appreciates ALL contributions from the community, whether it's highlighting a bug, or correcting a mis-spelled word, they all help..

But here, Bart appears to be talking about the default widget CSS, and not ad hoc CSS overrides offered in the forum;

He goes on to say;

...and that is what's missing, guy's with CSS knowledge contributing to the core nodes to correct these issues, without users having to apply CSS workarounds and fix them themselves.

This is going to be a little off-topic and also not even related to Node-RED but ....

I've recently started doing more BabylonJS "stuff", i.e., creating a particular 3D scene for a particular device, for a specific reason.

What I have discovered is that programmatic 3D is extremely complex. Using something like Blender to create 3D scenes is visual and hence (arguably) simpler to understand and get productive in. But coding 3D scenes and their interactions is really (for me anyway) complex. What makes it complex? Event handlers, observers, 3D shapes, 3D collision, physics, renders, shaders and everything else - the terminology. Then you need to understand the architecture of BabylonJS - how do the parts interact and interlink. What is the relationship between shaders, textures, materials, shapes, lights and cameras?

Fast forward: to create my "scene" what I had in mind, took some 2500 lines of JS code plus understanding 3D physics, memory management and all the above. That was three weeks of work and about three questions in the BabylonJS forum. I admit it's not a run & jump or anything particularly mainstream but more complex than rendering a Node-RED flow in 3D (which is also BabylonJS).

The point here is what made it possible that I was productive and never stuck creating something that I didn't know before?

For me, what made this possible is the BabylonJS playground where it is possible not only to create a fully functioning three-D scene in the browser using BabylonJS (i.e. I can test my code there first before entering a edit-save-deploy-test cycle), but it is also possible to save that code and post a link to it in their forum.

So that others can load that code, change that code and then save their changes (with a revision number) and repost their modifications in the forum. All that without having to login to the playground, no signup, no hassle, no installation, no server and all in their favourite browser. So the turn around for getting help is super quick: question + link to playground, someone opens link, changes code, saves code and posts their fix in the forum.

So the BabylonJS community has grown around a collection of examples linked stored the playground. The documentation is full of examples hosted in the playground that anyone can then modify, save and repost in the forum as part of a question. Or simply integrate into their own solution.

And because examples are extremely focused on the problem at hand, examples are easy to understand. And finally, as an added bonus, the developers of BabylonsJS have a huge repository of examples that people are using and have created for their needs - because they created them in the playground. This makes for regression testing for new releases ultra simple - just update the libraries of the playground and test all examples.

Imagine doing the same with Node-RED code - be it dashboard or flow code.

For newbies a vast repository of examples would suddenly be available to learn from.

Helping others would not require getting someone to post their flow here, then having to copy that flow data into a local running instance of Node-RED, analysing the flow and then suggesting a fix. Instead someone could go to the playground.nodered.org, recreate their flow there and then post a link to it here.

A vast repository of code would be generated that can help to test new versions.

I personally would say that Node-RED requires something similar because the complexity of flow based visual programming is the same (if not higher) that programmatically coding 3D scenes using JS in the browser.

This is quite off topic, but to focus on the NR specific point you've made, the difference between something like Babylon and Node-RED is that Node-RED requires server-side computation, additionally, it often involves hardware interaction.

Babylon is entirely client-side, so doesn't require dedicated processing power. They also have a whole team at Microsoft dedicated to Babylon development and community engagement too.

For Node-RED, there is https://flows.nodered.org too, which has thousands of example flows and third party nodes

there is a typo

for dashboard-2 ?

I think the elephant in the room was the choice for vuetify, a very opinionated and rigid framework which has a poor design/layout basis where everything is padded with spacing that cannot be modified, this trickles down where people want to create mobile-first layouts, where space comes at a premium and they end up hitting walls to work around these issues and css comes into play.

I don't think that is the case at all. One of the biggedy compliments I've seen for Dashboard 2.0 is the use of Vuetify because of its range of widgets and flexibility to customise.

There is no requirement to use Vuetify at all. Its entirely optional, and you can continue to write raw Javascript/HTML template as in Dashboard 1.0

I was not referring to widgets, but to the layout and paddings, where people can no longer fit buttons on their screens without resorting to css.

We have control over everything. Please do open issues on the repository with proposals. More than happy to provide alternatives for padding, etc as part of configuration

How long can we expect an issue raised on github to remain open with status "Needs triage" before anyone looks at it and comments?

Not asking about timescales for implementing changes, after all there is a backlog...

At the moment, my focus is away from Dashboard, but anybody in the community can work on any of the issues in the repo. It's an open source project, there is need for permission

Geez,

I am so sorry to have opened this can of worms @joepavitt - i know it has been a one man labour of love for you to get D2 happening and very much appreciate the work.

Please Please @BartButenaers Do not leave us !!

My background is in Network architecture, security, CI/CD etc and have always worked on the periphery with programmers - but never been a programmer by trade.

I am very good at taking some code someone else has done and modifying that (or destroying it) into what i want to make it do.

So maybe my frustration with DB2 is that there are not many examples of dashboard layouts

We are in the middle of renovoating, selling and buying our new house at present but once all completed i will start trying to dedicate some time to create new D2 dashboards and post questions here as my journey progresses.

Craig

1 Like

I would point out here that this is one of the driving factors behind the development of UIBUILDER. At its core, it was designed to stay close to HTML standards so that the ongoing evolution of HTML inherently benefits UIBUILDER and results in a long-lived approach.

Of course, this does mean that much of UIBUILDER is still code-based rather than pure point and click. But, to your point, if people focused on developing web components - which are HTML standards based rather than constrained to a specific framework - they would be usable everywhere, no matter what future UI capabilities appear.

UIBUILDER is now over 10 years old and continues to develop even though - like you have already mentioned - very little contribution has been made by anyone other than myself. And I am not a full-time developer. I fully anticipate at least another decade of development even if nobody else steps in to help. Especially when I retire and have, hopefully more time to commit to the project (should happen in the next 12m). If we had the community support that D2 has seen focused on UIBUILDER, we would doubtless now have far more components, more zero-code nodes and probably a layout builder.

Anyway, I don't want to side-track this discussion on D2 too far. But I couldn't bear not to mention something about longevity. I'll not side-track things further to talk about flexibility which is another focus of UIBUILDER.

Appreciate it Craig. We aim to provide more examples, but there is nothing like the creativity of a community. It's why, in my personal time, I created resources like International Space Station Data Stream to encourage more people to build Dashboards in hobby projects, etc.

Iā€™m a programmer based in Korea, working on product development. Iā€™ve already completed three projects using Dashboard 1.0.
However, there were many limitations and things I wished were better.

With Dashboard 2.0, all of those issues have been resolved.
In particular, the choice to use Vuetify in DB2 was an excellent decisionā€”absolutely outstanding.

End-user design trends are evolving, and we can't rely on plain JavaScript/HTML forever.
Change is inevitable, and many app developers are already building dashboards using more advanced JavaScript frameworks.

I imagine there must have been a lot of discussion and consideration before switching to Vuetify.
As a fellow developer, I deeply resonate with the passion and thought that must have gone into it.
I truly appreciate the dedication of the Dashboard 2.0 development team.

1 Like

That is, I'm afraid, where we must agree to differ. I've been working with large enterprises and national governments for over 40 years and I see very much where big-enterprises are investing and what tooling they are using.

But at the same time, I've been working on UIBUILDER for 10 years.

In that time, I've seen multiple front-end frameworks come into and out of favour and even got caught up with that myself. But, over that same period, HTML, CSS and their JavaScript API's have massively changed and improved. To the point where frameworks are often no longer needed.

Frameworks still have a place for large-scale programmes with large programming teams for sure. But for the kind of development I've seen happening most when combined with Node-RED, the need is far smaller and, as we've seen with the demise of D1's underlying AngulaJS v1 framework and the debacle that was the Vue v2->v3 migration, tight integration with a framework can often bring unwanted dependencies and issues.

If D2 had been tracking industry practices, it would have used REACT rather than Vue. I'm glad it didn't because I very much dislike using REACT, but it is the industry leader by a long mile.

So, we absolutely CAN rely and indeed HAVE to rely on HTML/CSS/JavaScript since those are, for the foreseeable future, the languages of the web and the frameworks themselves have to track them.

And others are ditching frameworks. While still others find themselves hopping between different frameworks. Or, worse still, resorting to multiple frameworks.

Again, if you are a development house with a team doing large-scale web developments, doubtless a framework can be a helpful overlay. But most things that once took frameworks to do can now be done with vanilla HTML/CSS/JavaScript.

Anyway, we are in danger of descending into an us vs them type argument which is not the purpose of this forum.

The decision was made to use VueJS v3 along with Vuetify for D2 and so it must continue.

For those who want to make use of their existing web development tools, frameworks and teams, or who wish not to use a framework and keep things lightweight, there is UIBUILDER for Node-RED.

We ALL appreciate the work that people put into the features that we use. :slight_smile: