-
-
Notifications
You must be signed in to change notification settings - Fork 3.1k
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
Fix collection failure if entry fails. #1093
Conversation
Deploy preview for netlify-cms-www ready! Built with commit 2b01649 |
Deploy preview for cms-demo ready! Built with commit 2b01649 |
@Benaiah Do you see any problems with this? I'm thinking we should eventually do some sort of toast notification if a file fails to load, or something like that. |
src/backends/backend.js
Outdated
@@ -133,6 +133,7 @@ class Backend { | |||
const extension = selectFolderEntryExtension(collection); | |||
const collectionFilter = collection.get('filter'); | |||
return listMethod.call(this.implementation, collection, extension) | |||
.then(loadedEntries => loadedEntries.filter(loadedEntry => !loadedEntry.error)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Filtering out entries that failed to load seems like an implementation detail of the backend to me, and signalling by resolving to an object with an error
property is pretty confusing, especially since it requires coordinated keys in two different files. I would suggest one of two refactors:
- This
.then(x => x.filter(...))
line could be moved intosrc/backends/github/implementation.js
, right after thereturn Promise.all(...)
line. (This is the refactor that seems best to me.) - You could do all the filtering here by dropping the
Promise.all
infetchFiles
and returning an array ofPromise
s instead, then map.catch
over them here, instead of insrc/backends/github/implementation.js
. (I don't like this refactoring as much - catching these errors seems like a detail that should be handled by the backends.)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed, I'll move it.
@tech4him1 doing a notification eventually sounds like a good idea. I think we should have a way for backends to signal errors that can be stored in redux to trigger notifications/correction logic/etc. That would go well with the plan to have backends store their state in the redux store. |
@Benaiah How would you see this signalling happen in this fetching scenario? Would there be a function passed down to the backend, or would the backend pass an error object back up? |
@tech4him1 my first instinct is to do this by passing a function into the backend. Let me know what you think about this design:
|
@Benaiah On the second one ("optional errors"), the backend would return successfully after it registered the error. Then the higher-level component can decide to re-call the backend, but that would be a separate call and action chain. Right? I don't see any inherent problems with that outline. |
@tech4him1 yeah, that's my thought. The backend may need to be involved in deciding on a resolution for the error, but we can do that by passing that info back up the chain. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
@tech4him1 I don't care for greyed-out UI elements - they seem non-interactive and they don't explain why they're greyed out. Maybe if we displayed it similarly to a validation failure, with a small attached message in red explaining that the entry failed to load? Additionally, an entry that fails to load won't be able to show up as a standard list entry, since we don't know any of its metadata, such as its title (it would have needed to load for us to know that). There's also the issue of nontechnical users not understanding why entries are present in the entry list but cannot be loaded or interacted with. IMO an error message is the simpler option, since I don't see easy solutions to those concerns, but I might be missing something. |
@Benaiah The only reason I don't like a standard toast error message is its timeout -- it doesn't seem to work that well for stuff like this, where multiple entries could possibly have failed. |
@tech4him1 what about something like "Some entries failed to load, please contact your CMS administrator or see the console for details`? I don't think the actual error messages are going to be very actionable by non-technical users anyway - I'd just want to communicate to them that there's a reason that some of the posts may be missing. I'm guessing that anyone capable of fixing their CMS deployment based on the error message is likely to already know how to open the browser console. |
@Benaiah I don't see any problem with something like that, as most cases aren't going to be actionable by the user. There are some exceptions such as creating a new file that doesn't exist (for |
@erquhart Do you want to add a toast/notification to this before merge, or do that later? |
That's an improvement, I want to start merging stuff fast. Let's get this in and worry about improving in a separate PR. |
sem.leave(); | ||
reject(err); | ||
console.error(`failed to load file from GitHub: ${file.path}`); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great, let's merge. |
- Summary
Before, if any entry in a collection failed to load, the entire collection would be empty. This PR hides only the files that actually fail, instead of the entire collection.
Partial fix for #1092 and #929.
- Test plan
- Description for the changelog
- A picture of a cute animal (not mandatory but encouraged)