-
Notifications
You must be signed in to change notification settings - Fork 292
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
save state / versioning #141
Comments
I was searching for this one. This would be super helpful! To add my thoughts on what this might mean: I love the browser extension Stylus, which allows me to use custom CSS on websites I frequent. I use it to constrain the central column and override fonts on Gmail. In the past, I have customized headers on Dropbox Paper to help me navigate long documents more quickly. Currently, I'm enjoying a pleasantly-thorough GitHub dark theme, powered by a community of people. The great thing about Stylus is that I can actively use and navigate a website without even thinking about Stylus, but then I can edit a style if I want to, and it will be preserved as I continue to use the web. If a designer could do this while navigating their product or website, it would make VisBug a sort of "interaction design tool" of a new and very useful kind. They could try a new typeface globally on their site, or edit the type scale, change the background, etc – and then experience how it feels to use it. That may all be exactly what you had in mind. Just wanted to share how I would hope to use it! |
i pitched a visbug feature just like how Stylus works, really early on, and i still think it tells a great story and has a nice use case! i wanted to use "local overrides" in chrome, a way you can already persist changes and have them automatically applied to a page (no extension required!). essentially the story can be summed up as "make any webpage your own." have you seen this tool, it's a new and nice stylus https://www.styleurl.app. i have an opinion, that i'm waiting to be replaced with something better, which is that.. while this feature idea is awesome and tells a very compelling ux story, i gotta wonder why designers arent rockin stylus, recss, or styleurl today? why why why right? seems like tons of value, but apparently not? that logic path alone has halted me really attacking the "patch some css onto this page after load" story. have thoughts on this? and yeah, overrides are different then versioning/saving state.. but they are related in many ways. perhaps i should break this out into 2 tickets? |
Ohhh awesome, thanks for recommending styleURL – it seems quite promising!
I think this comes down to a few reasons:
Holy crap, local overrides is amazing! I'm learning all sorts of new things, here. I'll have to try that out soon. |
hi Adam, i am trying to make a "Save to Netlify" feature but am a bit lost about how to hack this together. i edit using visbug and the dom changes in the dev tools, but when i run thanks |
@sw-yx interesting! that's so sneaky/fishy sounding, i love it. i haven't tried what you're doing, lemme see if I can reproduce that. that's a cool feature idea though, treating visbug modified pages as an immutable state of the page (if i'm understanding your plan correctly) |
yes that is exactly the plan. save to an immutable deployment. its free on netlify so why not lol. part of me is also wary that youve probably got something similar cooking so i also wanted to post incase this was unnecessary work i was running it in console. it definitely did not work, i tried quite a few different ways. im on vacation now but i’ll record a video sometime to demonstrate what i tried. anyway, if theres a button or method you wanna expose that just dumps all the html/css, then its a simple process of sending it to the Netlify drop api for saving/sharable deployment and i figure thatd be great for your users |
yep, an idea like this would be great, like a netlify plugin that lets you sign in and use an auth key to push builds. i'm not working on anything like this 👍 i don't know of any easy ways to get work out, but there might be helpful stuff with the extension api's? it's a tough one i think tho, dependencies need crawled and stuff? or urls need changed? i think the immutable visbug version deployment idea is a good one, but i dont have too many answers yet! |
well there wouldnt even need to be authentication :) netlify is set up for anonymous deploys and we dont need dependencies either if we’re just taking a literal snapshot of the visbugged DOM... |
There might a way to solve this similar was draft-js has done rich text editing. We create a model (a JS object representation) of the changes or just the current snapshot added to the DOM and store it so that it can be applied again. |
Having a JS model will open up whole world of feature set like building additional plugins for this and undo redo downloading the changes and sharing them playing these changes as a timeline, collab editing..... But also will make codebase easier to manage but it may require some work. |
update - i'll own up that i just never got time to do this and am working on other projects now. i'll happily answer qtns for anyone interested in working on this. |
@Rafi993 i'd love to hear more about the strategy ya'll used, VisBug will need to eventually move to an abstraction of the nodes, where right now it works right against the DOM i stumbled upon this tool recently and while it does similar things to Styleurl.app and others, I found it interesting that it uses your google account to stash the changes. I mean, most folks installing extensions probably are signed into Chrome. could be a clever way for VisBug to store state too, stash it onto a google account, and let it follow you that way. |
Still thinking about this, there's so many fun ways to share the work, it's hard to pick one:
Here's the values I'm thinking should help guide us on our 1st solution:
your thoughts!? |
Ramdajs does awesome work on this https://ramdajs.com/repl/ they encode everything in url and you can share the shortened url to others. I built something similar to that too https://cp.js.org/ for my personal use. |
But still need to check if there is any max length that url. |
@argyleink But how would you correctly save state when working with dynamic pages? Take Youtube's homepage as an example. On their homepage, the featured videos are different for each user and they can change on each page request/refresh. Obviously, if you tried to make changes to such a page, and compare the resulting HTML using Git, you'd get a bunch of false positives on which areas of the page have actually changed... So, it seems to me that the only way to incorporate a That way, you have a static version of the page that can be used to compare new content and code changes against. Side-note: I wonder if the native "Save Page As..." (or .mhtml) features of Chrome can be extended to help save VisBug pages and their state? |
we could host the state of the static document when the save button is hit. the changes wont apply to the existing app's dynamic state, we'd be sharing the modified static document edited in a browser. at least, that's one way to "share or save your work." this method is specifically advantageous when showing DOM changes made, not just CSS changes.
i've got a branch where visbug can pass around an object between instances and re-apply them in order. this could let us store changes in the url or in a gist, and then reapply them to the page using a visbug plugin or command. in this case, it's less about a diff, and more about latest computed styles being reapplied to their target nodes.
hard to pick a strategy, they all have tradeoffs! 🙂 thanks for spinning up conversation about it 👍 |
I think we're on the same page then. Especially when you mention:
Creating that static document, however, seems rather tricky... That's why I mentioned things like They feel unreliable though... Could it be considered impossible to save pages through the plugin if the browser itself cannot do it consistently? We're only concerned with saving a page's HTML and CSS, right? Media and scripts do not matter? I'm interested in that branch you mentioned. Rather than store state exclusively with code (.html and .css), did you have some sort of "action" system in mind? Like some kind of logger(?):
What you describe makes me think of Redux's time travel feature (undo and redo features too). I want to help implement this feature, I just don't know where to start... Should I look into how to accurately save a page using Chrome? Or like make PR to add logging of VisBug actions to a file? Build something to compare VisBug static documents? |
When we make changes using Visbug we can start recording changes in array of objects and when user opens up the web page again we apply those changes again to the page. For this to happen each operation that is possible using Visbug should probably be represented using action type and payload (like redux) with the payload being the location on which change was made and the change made (like text that was added). |
So if user edits a text and then replaces image using visbug this local array would be
as a bonus we also get ability to undo and redo too. |
I think having some sort of state store would be great while working on a site. Keep things fast and in memory. However, when saving a file, I think the file itself is the stateful object. I think teams would rather pass around a HTML and CSS file rather than a JSON file... Well it depends, really, if you want multiple export formats? Again, I don't think its possible to reliably recreate a document without versioning (making a copy of) the original page itself. |
What I was essentially proposing was something similar to this https://youtu.be/feUYwoLhE_4 |
For storing state |
Here's a link to #371 which started work on a few things and is a good place to check what changed so all messages passed through a central location. by doing this we can get a visbug api to:
a few goals out of it:
it's pretty half baked at the moment, but does prove the concept. sounds like y'all have a good grip on the array of patterns to choose from to solve this, redux style payloads and the idea of time travel is along the lines of where the PR intend to head. what kind of questions does all this raise for you? |
I'm game if you want to incorporate Redux or Flux-style architecture into this project. Regarding state, however, I am more concerned about creating "savable" projects. If I am a designer, and I start tinkering with a page, I want to be able to come back to it the next day (after closing my browser window)... It has to be stable and portable. This is why I think I'm going to look into things like versioning pages, saving pages, and common file formats (export to .html/.css, .pdf, .doc, .json, etc.). Something I could Hopefully I'm not alone in wanting this feature. I consider runtime state management and resting state management (data storage) as separate issues. In fact, if it makes things easier to discuss, I can create a new issue or thread for this. |
Yes, cool, thanks for bringing it back to this issue topic again, was veering off a little bit there into undo/redo and friends. If you've got ideas for stashing the current page state, go nuts. @sw-yx was hoping to just grab outer html, zip and push to netlify, which could easily be a plugin and a pretty blunt force way to do it, but potentially quite effective. the most promising idea i've heard, especially for designers, is revisiting old tech that allowed saving a webpage as a png, which i believe is similar or the same as the so yes, savable changes, in any form, would be awesome. let me know how you're most comfy attacking this feature and i'll share details about execution if i have any. |
That sounds good. Makes sense to me. The And yeah, I do want to attack this one. |
fun fact, the best place to chat for me is gitter or twitter, or start a PR? stoked you're attackin it! everything you need is sitting right there in the browser page right?! modifications are inline on that markup, excited to hash this out more with you. being able to share changes not as a screenshot would be really nice in many cases. thanks! 🙏 |
Oh, really? I had no idea about that aspect of I'll follow you on Gitter and Twitter then. Let's get after it! |
going to play around with this as a companion plugin https://github.com/gildas-lormeau/SingleFile |
No description provided.
The text was updated successfully, but these errors were encountered: