-
Notifications
You must be signed in to change notification settings - Fork 1.2k
This issue was moved to a discussion.
You can continue the conversation there. Go to discussion →
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
local UI for data and pipeline management & visualization #3766
Comments
Also, I would also work on it myself, though I have to admit I'm not a UI guy. :) |
Related #1074 |
@vojavocni hi! that sounds great, do you want this UI to be run "locally", on top of your local repo? Or some SaaS that connects to Github? |
@shcheklein I would like it to be run "locally", as it would ideally allow modifying the actual .dvc files, or creating new ones. Something like a jupyter notebook. Then the user can decide weather he wants to push those to the repo. |
@vojavocni yes, makes sense! Okay, the next question would be - should we integrate with some IDE or build an independent tool? Do you have any technology in mind already (Electron or browser based - like run local server, open it in browser, etc). |
@shcheklein I was primarily thinking about running a local server and using the tool in a browser. It seems most universal to me. I haven't really thought about an IDE, tbh. From my personal perspective, I would prefer a browser based tool, but I'd also like to hear other people if they tune in here :). |
@vojavocni I still have certain doubts about running it as a server to be honest, but we can try to hack something quick if you feel that browser is better. Why do I have doubts. Web UI dashboard makes sense for Airflow, because Airflow primary goal is to run DAGs on a schedule, remotely, Kinda production ETL use case. While DVC is more like Git + makefiles. DVC pipelines potentially could be used as a replacement for Airflow, indeed, but it's not the major use case as far as I understand at the moment (may be I'm wrong? do you use DVC in that way?). When you use DVC locally on the hand for experimentation, the closer you "blend" with regular environments - IDEs, Jupiter, CLI - the better. It decreases complexity in adoption, it means that you don't switch between different environment, for example, to edit files and run something, etc. Also, VS Code is really powerful this days - it can cover even remote execution case nicely. |
@shcheklein Hmm, yes, I see your point. Now that you mention it, and since I'm using it, having some integration with VS Code might be a very good idea. Since I know VS Code supports notebooks, I guess it's doable to create an interactive UI inside it for dvc? |
@vojavocni yep, since it's a regular JS (TypeScript), I think it should be possible to implement this. But first step can be as simple as some support for |
@shcheklein Sure, I'm definitely in for starting with simple features like pull/push and maybe reproduce. Initially, some kind of visualisation (a nested list, for example) would be good. This can be easily turned into a DAG for eye candy. I will think about this as I use dvc, and post if any interesting features comes to mind. EDIT: Some of the features I realized would definitely be useful is efficiently renaming things from the UI, where all dependencies would be updated accordingly. To be more general, editing the stages without breaking the pipeline using a simple and intuitive interface. |
@vojavocni yep, I agree. I would also probably start with just trying to do what Also, I would recommend to take a look at the DVC pre-release 1.0a - it introduced a single DVC-file. Which means that pipelines are effectively saved into a single file - so it's easier to edit the dependencies now. I think it would be great to have visualize and edit helper still though. |
@shcheklein Would definitely like to see DVC integrated with VS code as this is something our team is adopting and having an UI would be a really great add on! |
@shcheklein can we elaborate on how the VS code plugin should look like. What features should it support while integrating with DVC. Some ideas I was getting are:
All these are exploding in my mind 🤯 😄. But I am not able to concertize these. Need teams help in detailing (roadmap) and explore possible implementation approach. |
@PuneethaPai we've started building some parts of this. I can invite you to the document with the roadmap if you want to participate. But this is mostly JS, we can definitely use some help if you are open to do JS. |
Sure @shcheklein. I am rusty with JS, but would love to work on it. Pls add me to the team. Thanks |
@PuneethaPai done! ping on Discord if you want to be involved and help with some things there. |
Hey @shcheklein I am open to work with JS. I know it is late but is there any way I can contribute? Love this project! |
@rakesh4real sure! please contact me directly on Discord please, let's see what would be the best way to involve you! (dvc.org/chat - find |
I believe that a UI for data and pipeline management will be helpful :) |
This issue was moved to a discussion.
You can continue the conversation there. Go to discussion →
I really think a web UI for dvc would be a big step towards much wider adoption of the tool. The simple DAG view of dvc pipelines (kinda like what apache airflow has), with the ability to edit the stages, reproduce them and visualize their status would make things much nicer.
An example of a airflow DAG:
Disregarding everything else on the airflow UI, what I was thinking is a DAG representation of pipelines that is similar to the one on the image, but also interactive - you can click on a stage and edit the commands or dependencies as you see fit, reproduce stages with a click, add a new stage in the UI just by creating an edge between the stages and specifying dependencies manually, etc.
I would really like to hear your opinions on this, I feel like it would be a big deal.
The text was updated successfully, but these errors were encountered: