-
Notifications
You must be signed in to change notification settings - Fork 17
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
[Discussion archive] File Browser #9
Comments
There should be a mechanism to remove files, but it should be undoable, via a trash metaphor.
|
Why do I need a file browser? What am I trying to do when I use it? WebUI is catering for people who want to administer a remote gateway (security issues aside) but it's also a general interest tool for anyone running an IPFS node on a desktop too (at the moment). For and admin, the file-browser is a way to keep an eye on what content is being hosted on a shared gateway... just a rough heuristic sort of oh look at all those CIDs, with the ability to click on one and have a look. A desktop user is more likely to be looking for a file they previously shared, and want to share again. As the IPFS repo structure is separated from their OS file-system, and not transparently viewable in their regular file browser, and files added to the IPFS repo are duplicated from the file system, it seems unlikely that people will be integrating IPFS in to their day-to-day file organisation now. IPFS could be the best "~/Public" folder ever, but there is friction around using it in that way. I feel like we have to consider rethinking IPFS Desktop's file browsing feature as a native OS file-browser integration to really remove friction for a casual user. |
I may be opinionated here, but I'd say people who administer a gateway will ALWAYS prefer to use CLI tools instead. File Browser listing thousands of raw CIDs is simply a bad UX for such low-level things. AFAIK the "browser" for low-level things will be "IPLD Explorer", which is tracked in #11. File Browser provides a great frame for delivering some of key features of IPFS for Desktop users:
My current design sentiments:
|
I fully agree that WebUI currently doesn't do a great job of visualising files for a gateway maintainer. I agree that most admins would like to use a cli. From comments on security issues where people have wanted to expose their WebUI on a remote system, I think we have to consider that some people are currently trying to use WebUI to see what's on their node, or at least as a reassuring visual counter part to the cli tool. That it doesn't do a great job of it, but people still want to use it is an interesting data point. I mildly disagree that our first step should be to make a re-usable file browser that works well in all shapes and sizes. I'd like to check if anyone else supports the OS integration route, as I think anything short of that will be significantly limited in it's day-to-day usefulness. We can make a great custom file browser, but I want to triple check that such a thing is the best way to get people using IPFS to host there public files. I totally take your point about the dangers of embarking on an OS file-system integration effort, but I'd argue that, if it's possible, then it may end up being a similar effort to trying to make a really good alternative file-browser in html, but be of more value. I could be convinced either way. I think we have to make a really good file html file browser anyway if that is to remain a feature of WebUI. I'd really like to take some time to test some proof-o-concepts for the native integration to see if that could be a thing. @alanshaw has made good progress on OSX flavour https://www.youtube.com/watch?v=jXkTEBdM6aA ...that is the only desktop UX I can see really catching on. |
I agree that OS integration is a valuable proposition for managing local files, and I am sure will have it eventually, but in my mind it remains a nice-to-have feature in addition to basic-but-robust web-based File Browser. My key concern with relying only on OS integration is the difficulty to provide feature-parity across platforms:
|
Chiming in here, I intend to make go-ipfs's As for native integration, I wrote something a while ago for myself and put it up here The point I wish to make is that I made that out of necessity, I wanted to be able to link someone a file, using various non-default ipfs arguments, quickly, this worked well enough for me that people asked me how I was linking things out so quickly. I think integration like this is important if not critical for some people. Especially on platforms such as Windows where the stock command line experience is... |
My thoughts are that we're going to have to build/adapt a decent web based IPFS file browser and a native integration will be the end game. If you need just one reason then this - I need to see my files in my js-ipfs node running in IPFS Companion. This is simply impossible with native integration. I would love to see a good web based, OSS, file browser with a pluggable implementation. In the same way that to build a FUSE filesystem you just need to implement a bunch of functions for reading, writing and stat-ing - maybe even that same interface!? Before I got onto building a FUSE I was thinking I wanted to plug IPFS MFS into a web based file browser as a demo for FUSE is a good POC but I think it's a non-starter to require people to install FUSE to be able to use IPFS Desktop, unless we can find a way of integrating a FUSE install with our IPFS Desktop install. That said, we could go a long way into exploring what native integration might look like with that approach, and if we really like it, then we can get serious and remove the FUSE element. I don't know if your average casual user is comfortable with IPFS being an app they can drag and drop files into but they can't see them on their hard drive anywhere using the native OS file explorer. In the past I've not been comfortable with it and it's only as a developer that I've come to understand that there are different storage formats and you can't just browse everything with the Finder. I bet there's younger generation(s) that are fine with it though and I suspect that it's a mixture. One parallel is the macOS Photos app. Photos are stored in a "Photos Library" which you can navigate to using the Finder but double clicking on it opens the app. I cannot get to the files and I've definitely seen frustration with people trying to copy files onto a USB drive or select pictures to upload to Facebook. That being the case, it makes sense to have a native integration to avoid alienating those users who don't understand "where the files are going", but familiarity is the really big one - Using something you already have (the native OS file explorer) but with extra bells and whistles is probably way easier than learning a completely new app. I'm speculating that most people nowadays are comfortable using their native OS file explorer and I reckon that's probably what Dropbox also gambled on (ahem, researched well ;)). Dropbox is pretty popular and in my experience seems to be understood well by most people technical or not. It's worth pointing out at this juncture that Dropbox has a web based file explorer as well as a native integration. There's also the reason that IPFS has already done a lot of low level work to expose itself as a regular Unix filesystem. It seems rude to not take advantage of that when it's so easy to do so. IMHO a native integration and, as @olizilla put it, having the greatest public folder ever is a super valuable goal for anyone wanting to share files easily or build a website that's instantly available to browse. |
Ok, I feel we have a consensus that web version and native OS integration solve different problems and BOTH are required for IPFS being successful on "desktop". Both will happen eventually, but we should decide what has bigger priority in the short term (eg. what to focus on in Q2). I propose:
Does this sound good? ps. @alanshaw ping @hacdias, he did some relevant work at https://filebrowser.github.io (not sure how pluggable it is tho) |
About the File Browser I did, I think that with some work it could easily be used for IPFS. There would be some stuff to do though. Right now, File Browser relies on a WebServer so it is not really a Single Page Application (we don't use hash history) but I think that could be easily reworked. I could start working on that to try it out and see if I can plug it in 😮 |
@hacdias we'll definitely want you try that out soon, but not today. It'd be great to get ipfs/ipfs-desktop#619 ipfs/ipfs-desktop#617 fixed (manually setting the config is fine for now) and get a release of Desktop out with the usability improvements in. Please find some people to test ipfs/ipfs-desktop#613 as well. I'd like to work on some wireframes with @akrych before we jump to pluging in your file browser. We will absolutely want to use as much of it as makes sense, but give us some time to sketch out how the apps should fit together first. |
Sure, I'll work on fixing those issues right now. Do you have any ETA for those sketches? |
Unradical but worth mentioning. I like OSX finder. Specifically, clean, but not totally minimal. Context menus hide a lot of the work, which may not be appropriate for a web ui version. I use the keyboard navigation and preview function all the time. I dislike multi-pane views, i prefer to focus on one dir at a time but I fear that everyone prefers the file explorer they already know, and that we'll need to offer multiple views. left-hand side is shortcuts to often used directories, right hand is file list. but i don't like |
(Moved from: #44 (comment)) What I likeChrome OS file.appClean and calm, not much going on (especially in older versions)
Version with thumbnails may be bit too much tho: ownCloudWhat i like here is that UI is "faded to background" and what "pops" are your files (if you ignore "enterprisey" banner at the top 😅): What I did not likeBitcasaWhat I did not like:
Mega.nzWhat I did not like:
|
The file browser needs to show all the contents of the node*. Users need to be able to visualise what their repo is storing. It cannot be just MFS, because there will be many users who have already pinned things in their repo who need to access them, either to view them, share them, or unpin them. * Is it possible to get a listing of everything in the repo that is not pinned? It's important to know what else is in my repo because it might be utilising significant disk space and bandwidth. GC is not run automatically so users need to be able to determine if if they should run the collector. Similar to the "All Mail" filter in Gmail we should be able to browse the flat structure of the IPFS node and drill down into the hashes (if they are directories). As I understand it, the MFS root is just another object in the repo that is the current root of the IPFS MFS system. It should be labelled appropriately and perhaps brought to the top of the list. Each item should have a visual indicator as to it's file type. A directory icon for directories and a content specific file icon for files. Note: it's possible in IPFS for an object to not be fully present locally* (see return value for ipfs.files.stat). So, to keep the UI snappy and to avoid unnecessary network activity we should only use content sniffing if the content is available locally. Otherwise fallback to file extension, if in MFS, and if all else fails then just a generic file icon. * Is it possible to determine if a DAG node is fully present locally outside of MFS? Because of the flat structure, we should be able to filter our view on the dataset from all items to just the MFS items or just the pinned items. The root listing (all files) might look something like this:
A tree view might make things super complicated so I suggest we stick to a click through with a breadcrumb (similar to how IPFS Desktop currently works). The breadcrumb should give an accurate representation of the path we're navigating. Currently in IPFS Desktop an MFS path appears as "ipfs / foo" but this is not a valid IPFS path in either view, mutable or not. We should be consistent when displaying MFS and regular IPFS paths e.g.
When browsing the MFS path we should label or highlight it appropriately. In a future iteration we might want to add a column with the number of peers seeding a file or downloading a file that might click through to a list of per file peer activity. |
One interesting UX problem of this combined file browser is adding files. When deep in a non-MFS path, can I add/remove/edit a file? Are those features are disabled? |
Listing raw repoI hope I am not right, but listing everything that is in repo does not sound feasible. Think about raw repo as something like "browser cache". It exists as a low-level technical detail not designed to be browsed or micro-managed by a human.
Exposing low-level pinsLow-level pinning is being redesigned and may even go away. My initial take was that it should not be exposed via GUI for now. MFS provides the same feature, but in more intuitive form. MFS RootI don't think we are able to get CID for MFS root: Communicating disk usageYou pointed out a very important problem of user asking "my ipfs.files is nearly empty – what is eating the rest of my disk space?". I think we could address that by displaying a pie chart representing all used storage with chunks for "ipfs.files" (MFS) and "node cache" (everything else). It could be located on a dedicated "Stats" screen, or on a tab within "File Browser". And there should be "Run GC" button near it. |
We should be showing the CID for each file in the file browser view. It's a complicated and not particularly readable string, so there is an argument for truncating it by default, but a key aspect of all our guis is to help the user understand what IPFS does. Creating a strong association between file name (link name) aliases and there CID is a must have. |
Users are asking for this too, see: ipfs/dir-index-html#15 |
Here is an example of a file in 2 states. The top line is what the user sees when a file is being added. The add file progress bar is replaced a circular progress wheel, so it takes up less horizontal space and can be put in the same place as the status icons while the file is being added. The peers column isn't relevant while the file add is in progress, so it seems like a good swap. The second line shows the added file, with it's CID below the filename. The last 4 chars of the CID are subtly highlighted to help the user visually spot a CID that recurs, and give them more memorable slice of the CID for tracking things down. We don't know the CID while adding a file, so that space is used to inform the user about what is happening while we wait for the CID to be available. The peers icon is initially set to red / danger / low peer count. Asking the dht for providers will take a while, so we play it safe and suggest that this content is not well replicated, until we know better. |
Uh, I like the idea. I just don't think the last 4 characters should be highlighted with that color. They contrast a lot with the others. |
Looks promising! 👍 for the circular progress wheel. I agree with @hacdias, the highlighted CID looks a bit off. A way to circumvent that would be to highlight it only when hovering that row. I think that the peer icon in red is a bit too strong too, but maybe that's the idea 🤔 it could have its circles in white to show low peer count, and they would fill out in grey when the peer count goes up. Just a thought to keep it streamlined. |
@fsdiogo we wanted to warn people that "adding to your ipfs repo" is not the same as "uploading to the cloud". I think 3 empty circles that take on a fill as the peer count goes up could work, but then we'd need to communicate the issue of "no other peers have this yet, so it's not 'safe'" some other way. |
Hmm, got it. Still not sure if the peer icon in red is clear enough on its own. |
A clean and minimalist Web UI + Files screen by @patrykadas from https://www.figma.com/file/YTMV7cOMmDSfqw8BgwoncbJ5/IPFS-Desktop?node-id=0%3A1: |
Cool project from ETHDenver'19 includes a tile view of image-heavy file collections stored in IPFS' MFS: Refs: |
Incremental work on this is proceeding, eg in this shipyard pr by @hacdias. Is the intent to keep this issue open as a conversational thread? |
A pleasing file browsing is essential. People have strong opinions about how they should work and a lot of experience using native desktop file browsers on their OS of choice.
With MFS, IPFS has a filesystem api that we can map to a traditional posix / unix like filesystem. But IPFS also has additional concepts like the CID, immutability, and file sharing, content pinning that we need to find a good way to articulate to the user.
Should all IPFS apps share a common file browser implementation or should they redirect the user to an improved WebUI, so the reuse is at the application level? Should we implement an OS integration, so you see IPFS files in your preferred file browser? What does a great file browsing experience with IPFS super powers looks like?
Project description: https://github.com/protocol/pm-ipfs-gui/blob/master/proj-descriptions/FILE_BROWSER.md
The current state of things is described here: https://github.com/ipfs-shipyard/pm-ipfs-gui/blob/master/research/README.md#browsing-files
The text was updated successfully, but these errors were encountered: