WordPress.org

Make WordPress Core

Opened 7 years ago

Closed 3 years ago

Last modified 2 years ago

#24048 closed defect (bug) (fixed)

Code Editors: Increase the usability of Code Editor's files list

Reported by: Daedalon Owned by: westonruter
Milestone: 4.9 Priority: high
Severity: normal Version: 3.5.1
Component: Plugins Keywords: needs-patch
Focuses: ui, accessibility Cc:

Description

Regarding the list under Plugin Files in the Plugin Editor (plugin-editor.php):

  1. Plugin root directory does not need to be mentioned in the file list.
  1. In order to improve readability, directories should be marked in a way that distinguishes them from the filename.

Preferably directories should not be shown next to every file, but rather as headers, under which all files in the same directory are grouped. This would make the list a lot shorter, as currently most of the filename-and-path-combinations span two lines.

  1. The form of the list should be changed to limit the total height of the list. This is especially useful for plugins with dozens of editable files.

One way would be to use a < ul > element with expansible/collapsible directory headers, showing only the first-level directories and files by default.

Attachments (14)

File Structure v2.png (41.9 KB) - added by melchoyce 3 years ago.
24048.diff (40.6 KB) - added by WraithKenny 3 years ago.
WIP preview patch (contains 6531.11.diff)
24048.2.diff (45.4 KB) - added by WraithKenny 3 years ago.
24048.3.diff (58.1 KB) - added by WraithKenny 3 years ago.
24048.4.diff (72.1 KB) - added by WraithKenny 3 years ago.
24048.5.diff (30.2 KB) - added by WraithKenny 3 years ago.
24048.6.diff (30.2 KB) - added by WraithKenny 3 years ago.
24048.7.diff (16.7 KB) - added by westonruter 3 years ago.
Δ https://github.com/xwp/wordpress-develop/pull/281/files/ca82c90..dd2ae47
24048.8.diff (30.7 KB) - added by westonruter 3 years ago.
Re-add tree JS omitted from patch
24048.9.diff (28.3 KB) - added by WraithKenny 3 years ago.
24048.10.diff (29.8 KB) - added by westonruter 3 years ago.
Δ https://github.com/xwp/wordpress-develop/pull/281/files/39b8c83..443f28c
24048.11.diff (30.0 KB) - added by westonruter 3 years ago.
Δ https://github.com/xwp/wordpress-develop/pull/281/commits/048ec47
24048.12.diff (30.5 KB) - added by westonruter 3 years ago.
Δ https://github.com/xwp/wordpress-develop/pull/281/commits/9e5c401
sticky-file-list-header.png (121.8 KB) - added by westonruter 3 years ago.
Sticky heading for file list

Download all attachments as: .zip

Change History (75)

#2 @helen
6 years ago

  • Focuses ui added
  • Keywords needs-patch added
  • Type changed from defect (bug) to enhancement

I have to admit that I'm not super excited about the prospect of either making some kind of tree nav or implementing and then maintaining an existing, compatible script. Something native to jQuery UI sounds nice but it doesn't seem to have any traction.

I also rather dislike the idea of making this look and feel like a sustainable way to be editing files. I don't think we should get rid of the file editors, but I also don't see any reason to make them particularly convenient or comfortable.

I could maybe get behind some basic headers. Probably need to fix #6531 first or alongside.

#3 follow-up: @bpetty
6 years ago

We've certainly had numerous discussions about removing the editors. In fact, even as a developer who writes a popular plugin focused on making these editors more usable, I've still argued the case for removing them myself. I don't think they ever will be though.

Regardless, they are here, and as long as they're here, there's no reason to ignore patches that improve their usability. I wouldn't discourage contributors from writing patches just because a number of us continue to debate whether they should be in core at all.

As for relying on and distributing another 3rd party library in core just for a file tree view, and also adding the requirement for JS to use the editors, that's something that does need to be discussed. It's obviously possible (as we currently do) to provide an interface that doesn't rely on JS or any 3rd party libraries, and it's not terrible. Also, in my opinion, pulling in a new 3rd party library to handle things like this screams "plugin territory" to me.

We could go for a smaller and more simple patch that provides some basic UI improvements to the current functionality that takes advantage of faster and smaller AJAX requests to navigate the tree when JS is available without reloading the editor itself (and making it possible to navigate the tree without losing unsaved changes in the editor), but continues to fall back gracefully on it's current behavior otherwise.

I also would be interested to see some new designs around how files are listed, and as this has bothered me significantly in the past, seeing designs that don't incorporate file descriptions in the list itself or sort files by those descriptions by default instead of by filename. I find that incredibly frustrating every time I use these editors myself, and I know others do too.

Those are just a couple ideas that would be more realistic, and have a better shot at being applied.

#4 in reply to: ↑ 3 ; follow-up: @helen
6 years ago

Replying to bpetty:

Regardless, they are here, and as long as they're here, there's no reason to ignore patches that improve their usability. I wouldn't discourage contributors from writing patches just because a number of us continue to debate whether they should be in core at all.

Not totally sure who or what you're addressing. There's no patch here, and I don't think the debate about keeping the editors is anything beyond academic. They're staying. :)

Anyway, let's just remember that these are basic editors and we should keep things basic. Think of them as a stepping stone to learning about more full-fledged development. If we make them too fancy/IDE-ish, it conveys the message that it's a good idea to be cowboy coding all the time, when it's not. But, speaking from personal experience, they can be a great way for somebody to find a whole new world of things to learn.

Design/concepts and/or patches happily encouraged here. Again, it could be as basic as adding some headers and showing files in a reasonable order and grouping.

#5 in reply to: ↑ 4 ; follow-up: @bpetty
6 years ago

Replying to helen:

Not totally sure who or what you're addressing. There's no patch here, and I don't think the debate about keeping the editors is anything beyond academic. They're staying. :)

I wasn't claiming there was one, just clarifying that despite your comments, it didn't mean no-one should bother even submitting a patch (because that's what it sounded like).

If we make them too fancy/IDE-ish

Certainly not advocating building a full IDE here either. We're just talking about making the file tree (that we already provide) actually work the way it was intended to. If you think providing a way to actually select files to edit is too much of an "IDE feature", then we have a case for removing it entirely. We're not in the habit of adding half-working features just because we sort of think it should be there, but we've intentionally made it difficult (and in some situations here, impossible) to use in order to discourage users from using it.

I completely understand your concerns here, but we're not talking about optional new features like "jump to file", "find in files", syntax highlighting, line numbers, or anything like that. This is absolutely required functionality for selecting which file to edit. It doesn't get more basic than that.

#6 in reply to: ↑ 5 @helen
6 years ago

Replying to bpetty:

I don't even know what you're talking about anymore. If for some bizarre reason I was opposed to making this better at all, I would have closed the ticket. Let's quit this non-discussion so as not to scare anybody else off, because even I'm scared now.

#7 @nacin
6 years ago

Well, I don't know what either of you are talking about, so there. :-)

Right now, the plugin screen lists the path to each file. There are a few ways to improve this. One would be "grouping" each level and directory with a heading, and then all files below that header are inside that directory. This would probably be "flat", with a heading specifying the full path to that directory, versus some kind of hierarchy.

Another option is to actually show hierarchy. This would require some sort of tree. It doesn't necessarily need to be collapsible, and I really wouldn't think we need to bring in a new JS library for this. Simple nested unordered lists with a dash of JS would get the right result. If you wanted a full-fledged "tree view" file browser, I think that would be plugin territory.

I don't know which is best. And really, I don't know if either of them would be a significant improvement. Perhaps we could at the very least chop off a common path. Right now if you edit a plugin within a folder, you get the full path on top of the page (makes sense) but also the folder repeated all the way down the tree. Even just removing that one segment would probably go a long way to cleaning this up, and I don't think we'd even need to do much more than that.

#8 @Daedalon
6 years ago

I agree with Nacin. It would improve the UI significantly just to:

  1. Not display the common part of the path (the plugin root directory)
  2. Arrange files in groups by folders where the folder name is a header instead of being repeated for every filename.
  3. Make the list collapsible.

Any of the above steps would improve the usability considerably by itself, so it's best to implement even just one of them for 3.9 instead of making them all depend on the most debatable one.

The ideal end result would look something like http://www.jqueryscript.net/other/jQuery-Flat-Folder-Tree-Plugin-simplefolders.html.

To comment on 'cowboy coding', I'd like to emphasize that having an editor doesn't require using it carelessly. I know people (e.g. students) who do a bulk of their site development through WP-admin due to a limited ability to install anything. The editor can be used on a dummy site from where it's easy to copy the finished changes to a live one. For many of those who use plugin solutions, the editor in core was a crucial first step and is an important backup.

#9 @mordauk
6 years ago

Aside from visual aides, one of the main reasons I'd get behind this is simply to provide a way to edit any file within a plugin or theme. As it stands, the plugin / theme does not always make all of the files of the theme or plugin available. I'm not sure of the exact logic for how the files are loaded, but it seems that only files included directly into the main plugin file or theme's functions.php file are displayed.

The WP Editor plugin gets around this limitation by providing a browsable directory structure. I think it's overkill for what this ticket should and/or could introduce, but it does provide a nice contrast in usability to the current editor.

To summarize, I'd love to see the ability to show / edit all files within a plugin or theme instead of just some.

Last edited 6 years ago by mordauk (previous) (diff)

#10 @Daedalon
6 years ago

That's a good point, Mordauk. #6531 is a separate ticket about that.

#11 @helen
6 years ago

Yes, the bug regarding actually listing files should be fixed.

I in no way oppose improvements here. I am just cautious about going too far and people getting *too* comfortable in the editor, when they should probably eventually be encouraged to grow out of it if it becomes a common task. A nested unordered list with proper hierarchy and maybe some headers seems like it could go a long way.

#12 @chriscct7
5 years ago

I personally think this would make a great usability enhancement. I don't use the editors often myself, but I know alot of users do, and when trying to find a file in a several hundred file plugin, it's a nightmare in the editor currently.

#13 @DrewAPicture
5 years ago

Still no patch here, which is what this ticket needs to move forward.

#14 @westonruter
3 years ago

  • Milestone changed from Awaiting Review to 4.9

#15 @melchoyce
3 years ago

#41729 was marked as a duplicate.

#16 @melchoyce
3 years ago

  • Summary changed from Increase the usability of Plugin Editor's files list (separate directories, limit height) to Code Editors: Increase the usability of Code Editor's files list

FYI, been exploring some designs in #41729. I'll be uploading the most recent one to this ticket.

#17 @westonruter
3 years ago

In 41721:

File Editors: Introduce sandboxed live editing of PHP files with rollbacks for both themes and plugins.

  • Edits to active plugins which cause PHP fatal errors will no longer auto-deactivate the plugin. Supersedes #39766.
  • Introduce sandboxed PHP file edits for active themes, preventing accidental whitescreening of a user's site when introducing a fatal error.
  • After writing a change to a PHP file for an active theme or plugin, perform loopback requests on the file editor admin screens and the homepage to check for fatal errors. If a fatal error is encountered, roll back the edited file and display the error to the user to fix and try again.
  • Introduce a secure way to scrape PHP fatal errors from a site via wp_start_scraping_edited_file_errors() and wp_finalize_scraping_edited_file_errors().
  • Moves file modifications from theme-editor.php and plugin-editor.php to common wp_edit_theme_plugin_file() function.
  • Refactor themes and plugin editors to submit file changes via Ajax instead of doing full page refreshes when JS is available.
  • Use get method for theme/plugin dropdowns.
  • Improve styling of plugin editors, including width of plugin/theme dropdowns.
  • Improve notices API for theme/plugin editor JS component.
  • Strip common base directory from plugin file list. See #24048.
  • Factor out functions to list editable file types in wp_get_theme_file_editable_extensions() and wp_get_plugin_file_editable_extensions().
  • Scroll to line in editor that has linting error when attempting to save. See #41886.
  • Add checkbox to dismiss lint errors to proceed with saving. See #41887.
  • Only style the Update File button as disabled instead of actually disabling it for accessibility reasons.
  • Ensure that value from CodeMirror is used instead of textarea when CodeMirror is present.
  • Add "Are you sure?" check when leaving editor when there are unsaved changes.

Supersedes [41560].
See #39766, #24048, #41886.
Props westonruter, Clorith, melchoyce, johnbillion, jjj, jdgrimes, azaozz.
Fixes #21622, #41887.

This ticket was mentioned in Slack in #core by jeffpaul. View the logs.


3 years ago

This ticket was mentioned in Slack in #core by melchoyce. View the logs.


3 years ago

#20 @afercia
3 years ago

  • Focuses accessibility added

Quoting from https://wordpress.slack.com/archives/C02RQBWTW/p1507148635000268

might need restructuring for the html to be grouped differently the plugin files and theme files are printed very differently, and we'd like to use accessible tree structure markup

#21 @WraithKenny
3 years ago

The Plugin Editor markup is fairly straight forward, in that the files are organized as they are found in a file system directory, and the only modification is that the Main plugin file is moved to the top of the list. This is like a normal file browser.

However, the Theme Editor organizes by file type first, then lists out each file under those headers. When "editable extensions" is filtered to allow more types, the organization goes a little funky.

In this cleanup for accessibility, should we drop the grouping by filetype, or do a hybrid? (Leaving it as it currently is, with headers for ".js files" and ".txt files," seems less usable.)

If we drop grouping, we could move the most important files to the top, like styles.css and functions.php, while leaving the rest of the files in a normal folder view, like the plugin editor.

If we do the "hybrid" we'd group php (Templates) and css (Styles) but then leave all other files grouped together so that there are only 3 groups.

(I prefer the first option, 1 tree.)

Once we decide on that, we can build either 1 or 3 Tree Structures that @afercia (I think) had mentioned elsewhere (which I'm reading http://accessibleculture.org/articles/2013/02/not-so-simple-aria-tree-views-and-screen-readers/ to understand better).

#22 @melchoyce
3 years ago

Good thinking. Let's try this:

If we drop grouping, we could move the most important files to the top, like styles.css and functions.php, while leaving the rest of the files in a normal folder view, like the plugin editor.

#23 @afercia
3 years ago

Detailed explanation of ARIA roles, attributes, expected keyboard interaction, and examples of Tree Views in the ARIA Authoring Practices:
https://www.w3.org/TR/wai-aria-practices/#TreeView

The first two examples are about a File Directory ;)
https://www.w3.org/TR/wai-aria-practices/examples/treeview/treeview-1/treeview-1a.html
https://www.w3.org/TR/wai-aria-practices/examples/treeview/treeview-1/treeview-1b.html

@WraithKenny
3 years ago

WIP preview patch (contains 6531.11.diff)

#25 @WraithKenny
3 years ago

The attached patch is a Work in Progress. The Work is on the plugin editor (theme not done yet).

Patch contains:

It's a work in progress, so the new function can be renamed and moved, and the new design still needs to be implemented, and then build into the theme editor ... but I just wanted to get a working patch up on Trac for a preview and for early testing (accessibility).

@WraithKenny
3 years ago

#26 @WraithKenny
3 years ago

  • Keywords has-patch ui-feedback ux-feedback added; needs-patch removed

Patch is ready for review!

This ticket was mentioned in Slack in #accessibility by wraithkenny. View the logs.


3 years ago

This ticket was mentioned in Slack in #core by wraithkenny. View the logs.


3 years ago

#29 @WraithKenny
3 years ago

pardon, I didn't add the w3c js files, one minute...

@WraithKenny
3 years ago

#30 @afercia
3 years ago

Quickly tested the patch, I'm sorry I have no time to go in depth but noticed a few things worth checking.

Icons: I don't think we can use unicode characters directly in the CSS files. These should use the unicode escape sequence or, better, dashicons. See the dashicons f139 and f140.
For RTL: I think there's already a Grunt task that inverts f139 to f141 but worth checking.

Regardless they're unicode or dashicons, screen readers tend to announce CSS generated content. VoiceOver announces "Right pointing triangle" and "Down pointing triangle", we should avoid this generating the CSS pseudo element inside a span that uses aria-hidden="true", see also #40428.

Coding standards, minor issues to address for example:
$('#templateside [role="tree"] [aria-expanded]').attr("aria-expanded", false);
WordPress uses single quotes and spaces inside parenthesis: .attr( 'aria-expanded', 'false' )
Minor: HTML attributes are string, not boolean. Ideally, false and true should be 'false' and 'true' even if jQuery and browsers take care of this.

As per the ARIA side, seems to me it is working nicely with Firefox and NVDA. Instead, it doesn't work as expected with Safari 11 and VoiceOver. To my understanding, Safari and VoiceOver don't fully support tree views, they announce them as "table" and "list box" on the W3C example, but here they announce the items as "Link" and this shouldn't happen.
I've tried changing role="none" to role="presentation" and seems to me this pairs the behavior of the editor files list with the one of the W3C example. This sort of makes sense since the role none is new in ARIA 1.1 and maybe not yet fully supported. Would you mind double checking and see if that makes any difference for you when using Safari and VoiceOver?

Will attach a few screenshots to better illustrate.

#31 @afercia
3 years ago

Safari 11 + VoiceOver

Expected behavior (tree views not fully supported and announced as "table" and "list box");

https://cldup.com/sJL5nJvyME.png

https://cldup.com/MSgyMgYO-n.png

https://cldup.com/CToIzHY9CF.png

Behavior in the WP code editor:

nothing announced:

https://cldup.com/IvcE8BoPzu.png

item announced as "link"

https://cldup.com/9_Kr4ZdKxD.png

#32 @afercia
3 years ago

Firefox and NVDA

expected behavior (W3C example)

https://cldup.com/vDzsmIEj9a.png

Behavior in the WP code editor:

https://cldup.com/_T0hagaeh4.png

Seems to me this works nicely :) it announces "tree view", the total number of items, the current item level (level 1, level 2), the number of items in the current group, and the aria-expanded state.

#33 @WraithKenny
3 years ago

@afercia Thanks for the feedback, I'll work on those edits (code-style and generated content) tonight. I'm glad that you have no issues on NVDA, since testing on Windows is a pain for me.

I'm testing Safari with VoiceOver, and getting different results than you.

I am getting the same as you on the file voice over link, changelog.txt (instead of changelog.txt, list box) and I'm unsure as to what difference between their markup and mine is, but I think I can track that down.

As to the bin ▶ result, I'm getting the full bin ▶, collapsed, group. I did notice that it's slow (either Safari or the VoiceOver program) and occasionally responds with "busy". Additionally, the w3c library waits for window.load instead of ready, so that might be something also. Are there any console errors?

I've also noticed that out of the 4 examples at the w3c, they have "computed" vs. "declared" and "Directory" vs "Navigation". I went with the "Navigation" version as its markup supports links, but maybe I'll switch to "declared" instead of "computed" as it seems to work nicer, even on their demo.

I'm going to comb over our code to see if I can find the difference that's causing the discrepancies, and add the declared properties (which will take a bit more work).

One weird thing, on Safari with VoiceOver, when I expand a section, I get: bin ▼, partner-cancel.sh, link, partner-provision.sh, link, travis_install.sh, link, expanded, group (which is listing the nested items). When using Chrome, I simply get: bin ▼, expanded, list box. At any rate, I'll try to get it to work as it does on https://www.w3.org/TR/wai-aria-practices-1.1/examples/treeview/treeview-2/treeview-2b.html

#34 @afercia
3 years ago

@WraithKenny haven't noticed any JS error.
About the markup, consider role="presentation" (or none in the new ARIA 1.1) is used to not expose an element to assistive technologies. Basically a tree view expects just a "tree" (the ul in our case) with "tree items" as children (the a in our case) and the li is not exposed to screen readers. Worth noting since the ARIA roles override the native semantics, we could theoretically use any element, even a series of divs. The ul/li/a structure is used for convenience and interaction.

I wouldn't recommend you to use Chrome in combination with VoiceOver, as Chrome is not the best browser for screen readers. On a mac, always test with Safari + VoiceOver.

occasionally responds with "busy"

Hm it usually happens to me when I keep the Safari inspector open, then VoiceOver usually goes nuts.

This ticket was mentioned in Slack in #accessibility by afercia. View the logs.


3 years ago

#36 @melchoyce
3 years ago

  • Type changed from enhancement to defect (bug)

#37 @melchoyce
3 years ago

  • Priority changed from normal to high

Raising priority to get this more attention.

@WraithKenny
3 years ago

#38 follow-up: @WraithKenny
3 years ago

@afercia turns out the issue wasn't with role="none" (presentation seemed to have no effect that I noticed), but rather that it needed a root folder because of the way the w3c library was written. Rather than edit their script, I wrapped the files in a ul>li. This changed the design to have the folder lines encompass the whole tree, but I think it looks nice. (Thoughts on design @melchoyce?)

Another thing removed was the "nonessential" span that shows the path of the file under the filename, as it's redundant with the tree structure. I do have a question about the accessibility of it. Would having the path read, i.e. back-compat.php (inc/back-compat.php), list box add useful info, or is it just noise? I figured it'd just be noise, but can add it back in if it's desirable.

The patch is now equivalent in behavior to the w3c demo, as far as I can tell.

I noticed that if a file (as opposed to folder) is the last highlighted item (or initial item), Safari won't tab into the tree (but will in reverse!)... This is a bug in Safari apparently, because it does it without VoiceOver, probably do to its treatment of li's vs a's Luckily, besides this issue, Safari/VoiceOver seems to be working as expected!

#39 @pento
3 years ago

  • Keywords needs-refresh added

24048.4.diff needs to be refreshed now that #6531 has landed.

#40 in reply to: ↑ 38 @melchoyce
3 years ago

Replying to WraithKenny:

I wrapped the files in a ul>li. This changed the design to have the folder lines encompass the whole tree, but I think it looks nice. (Thoughts on design @melchoyce?)

The overlap with the current file styling is a little wonky, and I think it feels really cramped with the whole file list encompassed in the tree. Can we change that with CSS so only folders have the lines?

#41 follow-up: @WraithKenny
3 years ago

@melchoyce Sure, I'll rework that when I rework the patch without 6531's patch.

#42 in reply to: ↑ 41 @melchoyce
3 years ago

Replying to WraithKenny:

@melchoyce Sure, I'll rework that when I rework the patch without 6531's patch.

Thanks! This is working great btw :)

@WraithKenny
3 years ago

#43 @WraithKenny
3 years ago

  • Keywords needs-refresh removed

Patch refreshed!

I've left out the style-guide cleanup of the rest of the plugin-editor and theme-editor files, since it made it hard to see what changed.

I've adjusted the folder lines to only show for subfolders, and also added mobile styles that I had forgotten in the last patch. Also, the file list is now the same size as the code editor area, with scrollbars if needed.

I've tested on php5.6 and php7.1

Can someone confirm that it's OK on php 5.2 & 5.3?

#44 @melchoyce
3 years ago

Styles look good 👍

For some reason, though, clicking the folder names/arrows isn't opening the folders — I can only open via keyboard navigation.

#45 follow-up: @WraithKenny
3 years ago

@melchoyce are you getting any JS errors? What browser/OS? (I tested on Mac versions of Chrome, Firefox, Safari and Opera.)

#46 in reply to: ↑ 45 @melchoyce
3 years ago

Replying to WraithKenny:

@melchoyce are you getting any JS errors? What browser/OS? (I tested on Mac versions of Chrome, Firefox, Safari and Opera.)

If I was before, I'm not anymore — it's working again 🤷‍♀️

Let's update the pointer to cursor when hovering over folders.

@WraithKenny
3 years ago

#47 follow-up: @westonruter
3 years ago

@WraithKenny Some feedback:

  • Instead of adding new JS files for tree links, I suggest just adding the JS inside of theme-plugin-editor.js. That is, unless we know we're going to use it elsewhere. If we are going to use it elsewhere, then the scripts should be added as dependencies for the theme-plugin-editor script so that it doesn't have to be enqueued separately.
  • The inline scripts added should be added to theme-plugin-editor.js as well.
  • wp_print_theme_file_tree() and wp_print_plugin_file_tree () both take $label arg that doesn't have the right phpdoc type, if the default value is false and not a string. Nevertheless, I don't even see $label being used at least in the case of wp_print_theme_file_tree()`.

See review with context for comments: https://github.com/xwp/wordpress-develop/pull/281

An eventual enhancement would be to load the given file when clicking it without even navigating to a different page (just updating the URL with history.pushState).

@westonruter
3 years ago

Re-add tree JS omitted from patch

@WraithKenny
3 years ago

#48 in reply to: ↑ 47 @WraithKenny
3 years ago

Replying to westonruter:

Updated patch to have the new javascript in the theme-plugin-editor.js file, removed the unused $label param from the wp_theme_file_file_tree() and cleaned up the docs!

This ticket was mentioned in Slack in #core by wraithkenny. View the logs.


3 years ago

#50 follow-up: @westonruter
3 years ago

In 24048.10.diff (see delta):

  • Add missing semicolons
  • Update initFileBrowser to use jQuery consistently
  • Fix JSHint issues related to use of 'char' as variable name
  • Suppress JSHint issues from 3rd-party code
  • Fix jscs issues
  • Suppress eslint issues for 3rd-party code
  • Move initFileBrowser above 3rd-party code

@melchoyce Since the file list is now a scrollable container, should the current file being edited be scrolled into view when the page first loads?

This ticket was mentioned in Slack in #core-customize by westonruter. View the logs.


3 years ago

#52 in reply to: ↑ 50 @melchoyce
3 years ago

Replying to westonruter:

@melchoyce Since the file list is now a scrollable container, should the current file being edited be scrolled into view when the page first loads?

Yeah, let's load it with the selected file scrolled into view (but without any animation, I think)

@westonruter
3 years ago

Sticky heading for file list

#53 @westonruter
3 years ago

  • Keywords commit added; ui-feedback ux-feedback removed
  • Owner set to westonruter
  • Status changed from new to accepted

#54 @westonruter
3 years ago

  • Resolution set to fixed
  • Status changed from accepted to closed

In 41851:

File Editors: Display list of theme/plugin files in scrollable directory tree.

Props WraithKenny, afercia, melchoyce, westonruter.
Amends [41721].
Fixes #24048.

#55 @WraithKenny
3 years ago

Awesome!

#56 @afercia
3 years ago

  • Keywords needs-patch added; has-patch commit removed
  • Resolution fixed deleted
  • Status changed from closed to reopened

Found a weird behaviour with Chrome that's pretty serious for keyboard navigation.

Seems scrollIntoView() in Chrome is also altering the native tab order. To reproduce:

  • just go to the Theme (or plugin) editor page
  • press Tab
  • keyboard navigation should start from the document root, revealing the "skip link"
  • instead, keyboard navigation starts from the first file in the tree view (highlighted in red in the screenshot below)

https://cldup.com/7YQ0RAcdGs.jpg

  • click on another file in the tree view
  • page reloads
  • press Tab
  • keyboard navigation starts from the editor (focus is inside the editor)

https://cldup.com/Jpzt3Vyq7p.jpg

Comment the line this.scrollIntoView( false ); in wp-admin/js/theme-plugin-editor.js and everything works as expected.

Couldn't reproduce in other browsers, seems this happens just with Chrome (v. 61 both macOS and Windows).

Seems to me this is really a Chrome bug, I don't see why scrollIntoView() should alter the native tab sequence. However, it should be worked around: starting keyboard navigation form the middle of a page shouldn't happen in any case.

Possible options I can think of:

  • don't use scrollIntoView() and use some jQuery scroll animation instead
  • use the proprietary scrollIntoViewIfNeeded() that seems doesn't trigger the bug

scrollIntoViewIfNeeded() is already used for some reason in widgets.js, I've quickly tried it and seems something like this would work:

if ( this.scrollIntoViewIfNeeded ) {
	this.scrollIntoViewIfNeeded();
} else {
	this.scrollIntoView( false );
}

Aside: not sure why .each() is used here, there's only one .current-file at a time.

#57 @ramiy
3 years ago

Related: #42221 - RTL issues

#58 @westonruter
3 years ago

  • Resolution set to fixed
  • Status changed from reopened to closed

In 41864:

File Editor: Prevent the scrolling of current-file into view to also change initially-focused element in Chrome.

Props afercia.
Fixes #24048.

#59 @westonruter
2 years ago

In 42155:

Theme Editor: Fix styling of child theme notice.

Props westonruter, melchoyce, ndiego.
See #24048.
Fixes #42491 for trunk.

#60 @westonruter
2 years ago

In 42156:

Theme Editor: Fix styling of child theme notice.

Props westonruter, melchoyce, ndiego.
See #24048.
Fixes #42491 for 4.9.

This ticket was mentioned in Slack in #accessibility by afercia. View the logs.


2 years ago

Note: See TracTickets for help on using tickets.