Opened 3 years ago
Last modified 20 months ago
#42213 new defect (bug)
Code Editors: Filter autocomplete suggestions
Reported by: | melchoyce | Owned by: | |
---|---|---|---|
Milestone: | Future Release | Priority: | normal |
Severity: | normal | Version: | |
Component: | General | Keywords: | has-patch |
Focuses: | Cc: |
Description
I noticed when playing with some CSS earlier than when you start writing a property, the value brings up an autocomplete panel (awesome!) but it autocompletes with literally every value you can use ever. Is there a way to filter those suggested values by relevance?
So, for example, I do text-transform
. The autocomplete values should be uppercase
, lowercase
, capitalize
, none
, and full-width
, plus inherit
, initial
, and unset
.
Or, color
should only suggest colors.
Unsure if this should only be a CSS editor thing or what.
Attachments (1)
Change History (11)
This ticket was mentioned in Slack in #core by melchoyce. View the logs.
3 years ago
#3
@
3 years ago
The proof of concept patch is a working patch showing what would be needed to achieve the functionality.
(To test the patch, please enable SCRIPT_DEBUG
as it currently breaks the grunt build step because of the class syntax.)
The patch uses a couple utilities from Chrome's dev tools, most significantly, the CSSMetadata
class, which does all of the work. (and a shim for Array.pushAll()
.)
It also copies out a few of CodeMirror's own utilities. (a helper function from the CSS
mode, and the default bundled css-hint.js
for modification.)
This is really raw code, and a number of improvements can be made to improve it:
- Trim out unneeded code from
SDK.CSSMetadata
- Organize the new code into the main file better
- redo
getPropertyName()
- maybe not show so many vendor-prefixed values
The code isn't fully complete either. We'd have to import more of the dev tools, specifically, wherever Common.Color
is defined. (color based properties are erroring.)
Basically, this shows it can be done, it's just a lot of code.
#4
@
3 years ago
Note:
https://github.com/ChromeDevTools/devtools-frontend/blob/master/front_end/common/Color.js#L688
For teh color object
We'd also need to run the new chunk of code through a transpiler (forgot to mention it in the previous comment).
#6
@
3 years ago
- Milestone changed from 4.9 to 4.9.1
This issue was reported upstream in CodeMirror: https://github.com/codemirror/CodeMirror/issues/3570
The code that is part of 42213.1.diff is adapted from code linked to from there.
Given the size and state of the patch and proximity we are to RC, I'm going to punt this to 4.9.1. Thanks for working out an initial proof of concept!
We do appear to set some sort of association for this (see https://core.trac.wordpress.org/browser/trunk/src/wp-includes/js/codemirror/csslint.js#L3739) but either it's not intended to help with the autocomplete, or it is and it's broken. Needs more investigation, but I'm out of time right now.