-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Move navigation error state to the inspector #44486
Comments
@javierarce @jasmussen would you say defaulting to one "home link" is better than this situation? |
@draganescu I'd say yes, it's better to show something users can change than that error message, which doesn't help you to solve the issue. |
I'd say yes as well. I'd also be really keen to see the editor view match the front-end view as much as possible, especially in the default state. |
Ah, this is an interesting one, because an empty page list is accurate when there are no pages, whereas a "home link" would not be, and it might not even be user intent. Given a new WordPress install defaults to adding "About", that seems to further reinforce that if these pages are intentionally deleted, the user probably wants an empty menu. So I would avoid adding any home links or otherwise. In fact, as a fix to this, I'd show nothing! This would be accurate to the frontend, and probably to user intent. It seems like it should be an easy fix, we just want to make sure the block doesn't collapse into nothingness and can't be selected — so it probably needs a min-width and min-height so it's at least selectable. A harder fix I'd suggest to be low priority: show a literal placeholder, same as what you'd see if you have no site logo and insert one. (In 6.1 that shows a dashed outline indicating: there's a placeholder here that can be filled out with something, and for 6.2 a new style is being explored, see #44460) |
I would favor showing a clearer and actionable placeholder text, something like this?
I would also ensure that the "+" add icon is always visible. Would it be possible to default to selecting the Navigation Block instead of the Page List Block if there are no pages? |
What if you don't want any pages, though? What if the context is so constrained there isn't space to add a message? |
Mmmm... I see your point, @jasmussen. A generic placeholder would also work, but I feel that some text would be more inteligible. Regarding the "user doesn't want any pages" scenario, they could ignore it or even better, remove the navigation block completely? |
Created a PR with @mrfoxtalbot suggestion. |
I approved the PR, because it improves the situation. But I don't think it closes this conversation. My original opinion stands:
An argument was shared that if you don't have any pages, you can delete the menu. That's true, but the onus to "fix a layout" should not be on the user who just installed a block theme. To that end, I maintain that a page list block should show nothing at all when there are no pages, that this is the intended behavior, that it seems a simple fix. CC: @WordPress/gutenberg-design |
I'd agree with that, especially when the block is not selected. Perhaps a message could appear upon selection to clarify why the block is empty (and offer a way to draft a new page), but that would need some design exploration. |
I posted this in the PR. First time contributing so unsure where the discussion should be centered, but posting here as well for visibility. |
@jameskoster if the block does not display anything if there are no pages how do you know it's there to select it? |
Same as with a spacer. The bigger question is, does it need to be selected? Pages will show up as soon as you publish some. |
Spacer could be argued to be more intuitive as clicking on empty space should select the space. But inserting a nav block and then getting an empty space is not the same. |
They are separate blocks, sure, and I think it's valid enough to show a message in the inspector about the navigation being empty when you do select it. But it isn't clear to me why this is a case of delineating WYSIWYG. Similar to classic themes that define a location for a menu to be inserted, and showing nothing until you create one, why does it have to be different here? While you should be able to insert a navigation block anywhere, especially when you build out a theme, for the majority of people it seems likely to think their navigation block will be preinserted in a header, by the theme they activate. And rather than show them an error message that suggests something is in need of correcting, just let it be invisible until a blogger chooses to create an "About" page. |
Doesn't this sound weird? There is a content block that is invisible, but can randomly be found in the tree of blocks (list view). It looks broken, when in fact it's behaving correctly. I think this is yes a case where WYSIWYG should remember editing is not consuming - show a placeholder or something for content that has something going on. |
I hear where you're coming from, but I also think that's misstating what's happening. It's a content block that has nothing to show, and so it shouldn't show anything that isn't there, or isn't meant to be there. It is arguably a templating block that is meant to be there to provide a feature for a theme. And if the user of that theme doesn't want pages on their site, it shouldn't warn them every time they enter the site editor, or in the future the post editor with templates showing. It should be there so that suddenly pages appear in a considered place once the user decides to publish some. |
Why then does the group block show a border or the image show a placeholder? Why is the navigation block special? Do we just want to basically discourage people from building menus? 😁 |
We definitely don't want to discourage people from building menus, that's why by default, especially if you leave the navigation block in place rather than deleting it because of a confusing error message, it will automatically populate when you publish pages. And then you can select it if you need to customize it further. The group block and image blocks only show a placeholder when they are entirely empty. And even those cases, the patterns they follow are outdated and need to be updated. The site logo block, for example, is a good example of where I could see that generic placeholder pattern go, lean much more into the actual literal placeholder pattern you'd see from desktop publishing patterns of the old days. The main reason why we need to evolve beyond Also, both those examples diverge from the navigation block in that you almost certainly wouldn't insert empty image or group blocks in a header or footer template, whereas when building a theme, you definitely would. Just to broaden the conversation here, I'd really like to ping @WordPress/gutenberg-design yet again. On my side, it's not the strongest opinion in the world that the navigation block is truly invisible when no pages are published, the only strong opinion I have is that whatever message we do show does not cause layout shifts. |
This captures my perspective, in a nutshell. There aren't really legitimate scenarios that call for empty Image blocks, hence the placeholder. On the other hand an empty nav is perfectly legitimate – a theme might include the block, and the site may not have any published pages yet. There's definitely an argument that the user might want to consider removing the block if they don't intend to ever add any nav links – but there's no reliable way to know that which makes a persistent on-canvas notice seem heavy-handed. |
This is showing a placeholder if there is no logo. The placeholder implementation may be better than say group's but it's there. This also can be added by a theme, just like say a featured image, and then should it not show if there is no logo? I think both of you have a good point, except that it's IMO somehow unfinished. What is the general direction we're moving into? Should all blocks that have nothing to display show nothing in the editor in specific contexts? The navigation block is not empty when there are no pages, its displaying an empty page list block. The page list block is actually empty, the navigation block is not. It will also afaik render empty markup. I also suspect that this particular edge case will make people insert a new navigation block since they can't tell there is one already. And the same is true for all other blocks which are invisible if empty. The spacer block is the exception because it does show up as empty space.
Yes, I agree with this. We need a better placeholder system that is unified across blocks, does not cause layout shifts, is selectable and it communicates there is something there which is likely waiting on user action: configure or remove. This is the problem to solve in my head too. I too don't want error messages or informational messages in the canvas, simply because they're making the experience bad. We have the block inspector, toast notices, big yellow notices, lots of places. But we still have these messages because we don't have rules as to how placeholders work for when stuff is broken or unconfigured: what should we show, where to put the instructions? It should also encompas problems with block rendering itself and avoid this ugliness:
|
There's also #41747 which contemplates displaying block errors in list view. |
I like the ideas in #41747 @jameskoster. If we incorporate the last comment it could be the solution to this and then we could apply Joen's vision with just not showing anything. If we do that then we should go through the affected blocks in the library and maybe make them aware that they're "empty" so they don't render empty markup either. |
Yep, lots of notices worth showing:
|
This came up again recently. To try and unstick this, but without this being dependant on a linting interface, here's a new mockup: Situation: the menu that’s ref’ed is deleted. Result: Page List is shown in the canvas, an error message is shown in the inspector, with two buttons:
|
This is perfect as a stop gap. I'll move to description the mockup you shared @jasmussen 👏🏻 |
+1 this looks good. It's a tiny detail but I'm wondering about the button appearance. Is there a more common action here, and if so should we use a combination of button variants to represent that (primary + secondary, secondary + tertiary, etc)? If we feel equal prominence makes sense then we might consider a more subtle variant ( |
I just thought - what happens if there are no Pages on the Site (as per the original Issue description)? What do we show in canvas? |
Unless selected, do we need to show anything? If there are no pages on the site, then presumably the user is either building out their site, or they want a single-pager, and desire no pages to show up. Being able to have a Header template that still includes a navigation block, so that if one day the user chooses to publish some pages, they will automatically start showing up there, is still beneficial. If it continues to show an error message in the canvas, we imply the user is doing something wrong, which isn't necessarily the case. Options here are wide, though, the navigation block can show its placeholder state if it's selected, or if any ancestor is selected. To support that, it would be good to have a very basic placeholder state, even more basic than the current one we have today. Just like how the Post Content block shows some text, so you can style it, the placeholder state could show just "Navigation (empty)", in the same font and style and size as a navigation item would be. What do you think? |
I noticed something related to this issue. I was trying to reset some small changes to my site to its initial state, so I reset my templates, template parts, and I deleted my menus. However, every navigation block I insert seems to incorrectly reference the deleted menu: Kapture.2024-12-18.at.10.28.48.mp4I also couldn't delete the I think the proposed changes here would fix it, so I haven't made a separate bug report. |
I've seen this too, and it's been confusing to reproduce. |
I think we default to last edited menu and there to be an invalid state where deleting the a menu does not update the last edited id. That is why the problem is fixed when refresh. This issue does not fix that. This issue is about the UX of error state. @jasmussen just to make it clearer for me - are you proposing that the block is invisible in the canvas until the ancestor is selected? So the user knows there is a nav block via list view or when they try to insert one and select an ancestor of the place they'd like it to be in? That sounds good and it's also a separate issue. But is not a bad idea at all as currently it does draw too much attention. |
I think that's worth exploring, yes, because this would be true WYSIWYG but with affordances for editing the various interfaces. Once you start creating pages, they'll appear there. But that suggestion can be decoupled from moving the error message to the inspector, both to test in the plugin and learn, and to keep iteration simple. So what remains in the canvas when a block is empty and not erroring? It could be the existing dashed line placeholder. Or it could take inspiration from what other template placeholders like "Post content" or "Comment content" do: simply show some text. Such as: "Navigation block." |
I guess you'd still get the warning, but it's better as the page list is shown instead. It'd be less broken. |
Showing "last edited menu" might show the footer in the header, or am I missing nuance? |
I think the issue @talldan showed is perhaps due to the fallback menu ID being somehow stale in the state. The code path I imagine occurring is:
I would have expected that if the entity is deleted then the fallback state gets flushed but of course that won't necessarily happen unless we wire up the reducer to response to the appropriate action type (i.e. entity deleted and the type was What do you think @talldan and @draganescu? Does my theory sound feasible? Update: here's a PR illustrating a potential fix #68130 |
Description
Originally found by @jordesign this is a Gutenberg UX bug not a theme implementation issue. There is no clear programmatic fix, I think we need a better state for this edge case:
Step-by-step reproduction instructions
Screenshots, screen recording, code snippet
Editor
Rendered site
Proposed solution
Situation: the menu that’s ref’ed is deleted.
Result: Page List is shown in the canvas, an error message is shown in the inspector, with two buttons:
The text was updated successfully, but these errors were encountered: