Skip to content
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

Keyboard shortcuts support #71

Closed
21 of 35 tasks
jasmussen opened this issue Feb 15, 2017 · 44 comments
Closed
21 of 35 tasks

Keyboard shortcuts support #71

jasmussen opened this issue Feb 15, 2017 · 44 comments
Assignees
Labels
[Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). [Type] Enhancement A suggestion for improvement.

Comments

@jasmussen
Copy link
Contributor

jasmussen commented Feb 15, 2017

For accessibility and power-users both, we should always think about keyboard support. This was first brought up in #61, but deserves being fleshed out more.

The editor already has keyboard support for most formatting controls, including the "Paragraph" type switcher, which we are pondering moving to the side. Though since this will likely expand a fair bit beyond paragraphs, headings and preformatted, maybe that needs love too.

Many of these are existing keyboard shortcuts that should probably stay intact for back compat.

Inline formatting:

Hidden (?) controls:

Markdown-esque shortcuts/syntactic sugar:

  • Code: wrap text in backticks, `
  • Bullets: * or - on newline
  • Ordered list: 1. or 1) on newline
  • Blockquote: > on newline
  • H2-H6: ## - ###### on newline
  • Horizontal line: --- on newline

Insertion/block level controls:

Inserter:

  • Invoked where the cursor is, by typing / on newline or pressing ^⌥M, then / and Enter for select
@jasmussen jasmussen added the [Type] Enhancement A suggestion for improvement. label Feb 15, 2017
@jasmussen
Copy link
Contributor Author

jasmussen commented Feb 15, 2017

These two:

  • Open block type switcher ⌘~ then / and Enter for select
  • Toggle between block types ~

probably need the most discussion, as getting these right can potentially make for a killer feeling while writing.

Imagine this: type type type, churn out a blogpost, / on a newline, arrow down to image, enter, pick image with arrowkeys, enter to insert, write another line, press ~ twice to instantly switch it through heading and then to blockquote. Done.

In this situation, simply pressing ~ while inside a block switches it to the next compatible blocktype, so a paragraph would cycle over heading then to quote, whereas a gallery might cycle between gallery types. ⌘~ would actually open the switcher list so you could see the compatible blocktypes and pick one using arrowkeys.

Quip has this shortcut, worth trying out. But they use backtick `, which we are using in a markdown-esque way for code.

Important also to think of international keyboards. On US keyboards, the ~ character is in the top left, which makes it a sweet deal, easily accessible, whereas euro keyboards put the tilde under ⌥^, which is a fair bit more cumbersome. Any other ideas?

@jasmussen
Copy link
Contributor Author

jasmussen commented Feb 15, 2017

This one also deserves lots of thought:

  • Change heading size ^⌥↑ for increase, ^⌥↓ for decrease

For context, these shortcuts assume that a "Heading" is a single block type, and the heading size is a block-level property of that style. Mockup:

headings

👆 Note, that mockup has a different style of block level controls than the UI prototype currently has.

So the flow would be:

  • write text
  • press ~ to switch to next compatible block type, i.e. Heading — this would convert the paragraph to a h1 (or h2?)
  • press ^⌥↓ to convert the h1 to a h2

@jasmussen jasmussen added [Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). Design labels Mar 29, 2017
@jasmussen jasmussen added this to the Beta milestone Apr 20, 2017
@afercia
Copy link
Contributor

afercia commented Apr 29, 2017

Worth reminding some of these keys are not available on all the keyboard layout, for example ~.

@ellatrix
Copy link
Member

I can look into part of this together with the other text shortcuts, and where it touches Editable.

@paaljoachim
Copy link
Contributor

I think it would be nice to include keyboard shortcuts for the most used blocks. As it would be a quicker way to add the blocks one use over and over again. Perhaps even have a mention of the shortcut beside the most used blocks similar to various program list shortcuts.

@jwold
Copy link

jwold commented Jul 7, 2017

I've been thinking about the benefits of being able to write an article completely from the keyboard, without using a mouse. This has serious benefits for accessibility as well as for staying in the flow (kind of like when using Markdown and you can just keep writing while adding in quick formatting)

The ideal flow here could go like:

  • Start typing a few paragraphs
  • Type shortcut to open picker
  • Start typing “qu…” and have the quote block pop into view on the inserter and be highlighted as the number one result (Typing when the inserter menu has focus should start searching the blocks #1064)
  • Press return/enter on the keyboard and have the block insert into the editor
  • Write your quote
  • Press tab
  • Write your citation
  • Press enter twice
  • Continue typing

@jasmussen
Copy link
Contributor Author

Love those thoughts, @jwold, so much so that it was planned for a long time to use /, like Slack and IRC, to invoke a searchable block selector dialog. See #323 (comment) for full mockups.

This is a feature I'd like to resurface, but we've punted for now as it isn't critical to V1.

@jwold
Copy link

jwold commented Jul 9, 2017

Awesome! Would love to have this revisited in the future. Agreed that it isn't needed for a V1 launch though.

@markjaquith
Copy link
Member

Related: #5805

@afercia
Copy link
Contributor

afercia commented May 30, 2018

@jasmussen looking at this during today's a11y bug-scrub: do you want to keep it open as a tracker for all the other related, specific, issues or close it?

@jasmussen
Copy link
Contributor Author

Definitely close, as I believe we have most in, thanks. If things are missing let's open specific issues for sure. Thanks for the ping! 🍷

@afercia
Copy link
Contributor

afercia commented May 30, 2018

Ok thanks!

@afercia afercia closed this as completed May 30, 2018
gziolo pushed a commit that referenced this issue Jul 9, 2018
* camelCase for readme variable names

* update hook and `vendor/plugin/function` wording, removing `Name`

* complte namespace shortening to `vendor/plugin/function`

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* add publishConfig->access:public for hooks

* Publish

 - @wordpress/[email protected]

* correctly enable dashes in regexes in validateNamespace

* Export a hooks function enabling adding hooks via composition

* test hooks can be instantiated

* Run test on objects instead of globally

* correct data return for Hooks

* Rework the Hooks object, use a local HOOKS instead of global

* use object based hooks throughout testing

* remove unused global HOOKS

* remove some logging

* remove extra parts from namespace in tests

* remov vendor/plugin prefix requirement for namespaces

* update docs

* Add a test for “Can add filters with dashes in namespaces”

* a11y: Apply .screen-reader-text styles to container

* a11y: Update tests per updated style

Questionable value of the test assertions, which are specific to the implementation and not the expected intent of the test case

* update readme, add some tests

* switch naming to `createHooks` and correct tests

* remove extraneous single quotes

* remove the HOOKS global abstraction

* update test beforeEach cleanup to match new object structure

* use export defaults

* Clean up readme for new approach

* url - add built files

* hooks - add built files

* dom-ready - add built files

* a11y - add built files

* remove build filders from gitignore

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* re-ignore build files; didn’t resolve publishing issue

* Simplify dom-ready package.json, add a license field

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Update readmes to include `@next` in npm install line

Since our packages are still in pre-release, the @next tag is required to install the latest published version. We can remove this instruction once the packages are past pre-release.

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* remove the built files which were added by mistake

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Hooks: Update hooks public API to make it possible to apply to wp.hooks directly (#45)

* Development: Improve onboarding experience for new contributors (#46)

* Update screen-reader-text CSS.

* Hooks: Allow slashes in the namespace (#47)

* Hooks: Allow slashes in the namespace

* Hooks: Add test ensuring backlash is not allowed inside namespace

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]

* a11y & hooks: remove ‘@next’ from install instructions

* tag a11y and hooks at 1.0.1

* Trigger actions when adding or removing hooks

* add tests for expected hookAdded and hookRemoved events

* these are hooks not hoods (typo)

* Tests: Refactor tests to use Jest mocks

* Standardize format of package.json files (#54)

* Add tests for addFilter/removeFilter

* whitespace

* Docs update for hooks added/removed events

* Hooks: Final touches for the add/remove actions

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Update Lerna and Jest to the latest version (#56)

* Implement autop package

* Port PHP wpautop faithfully to JS

* docs: Update Lerna docs to use `npx`

* Update license in `package.json` to adhere to SPDX v3.0 specification

* Update license in `package.json` to adhere to SPDX v3.0 specification

* Enforce using the latest LTS version (8.x) of Node and up

* Move node version check to prebuild run script

* Remove superfluous `a` and use full Node.js name

* Jest-console: Add new package with console object matchers for Jest

* Jest-console: Add package documentation

* Jest-console: Integrate test matchers with packages repository

* Jest-console: Fix typos in README file

* Jest-console: Whitelist folders published to npm

* Update install instruction in README files that use beta releases (#63)

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* chore: Update `.editorconfig` to match WordPress' upstream

* chore: Use tabs for indentaion in `lerna.json`

* chore: Use tabs for indentaion in _root_ `package.json` and `package-lock.json` files

* chore: Use tabs for indentaion in _url_ package `package.json` and `package-lock.json` files

* chore: Use tabs for indentaion in _jest-console_ package `package.json` and `package-lock.json` files

* chore: Use tabs for indentaion in _hooks_ package `package.json` and add missing `package-lock.json` file

* chore: Use tabs for indentaion in _dom-ready_ package `package.json` and `package-lock.json` files

* chore: Use tabs for indentaion in _autop_ package `package.json` and `package-lock.json` files

* chore: Use tabs for indentaion in _a11y_ package `package.json` and `package-lock.json` files

* chore: Update _autop_ `package.json` fields

* Babel-preset-default: Add new package containing the default Babel configuration (#66)

* Publish (#67)

- @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Scripts: New scripts package containing test command (#62)

* Scripts: initial commit with scripts package containing test command

* Publish

 - @wordpress/[email protected]

* Scripts: Minor changes before publishing to npm

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* feat: Add `@wordpress/browserslist-config` package

* docs: fix spelling in CHANGELOG.md and consistent formatting

* chore: remove `browserslist` from `peerDependencies`

* tests(browserslist-config): refactor test per coding standards

* Packages: Make sure dependencies are properly exposed for external usage (#71)

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Babel-preset-default: Makre sure transform runtime plugin is not loaded in test env (#73)

* Publish

 - @wordpress/[email protected]

* 📦 NEW: Update Lerna to 2.8.0

* chore: use tabs for indentation in `lerna.json`

* build: use `browserslist-config-wordpress` Browserslist shared config (#68)

* build: use `browserslist-config-wordpress` Browserslist shared config

* chore(babel-preset-default): switch to `@wordpress/browserslist-config`

* chore: fix merge conflict

* chore: regenerate `package-lock.json`

* Browserslit config: Add devDependency in the root repository

* Babel preset default: Add missing spaces around square brackets

* Jest preset: Add default jest preset for WordPress development (#74)

* Jest preset: Add default jest preset for WordPress developmnent

* Jest preset: Use path to jest preset relative to root directory

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Tests: Fix wrongly configured dependencies for Jest preset (#75)

* Publish

 - @wordpress/[email protected]

* Dependencies: Update Jest preset dependencies version (#76)

* Build: Symlink all child packages instead of using versions published to npm (#77)

* docs: add link to browserslist usage examples docs (#80)

* docs: update browserslist readme example usage

* docs (browserslist): Link to external configuration examples

* Update README.md

* chore(browserslist): update Browserslist to v3.0.0

* chore(browserslist): update Browserslist to v3.1.0

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* chore: update Lerna to 2.9.0

* Build: Use node script to symlink local npm dependencies (#79)

* Build: Use node script to symlink local npm dependencies

* Chore: Update symlink-or-copy to v1.2.0

* Chore: Added npm-run-all to simplify npm scripts

* docs: ❤️  Code is Poetry

* docs: use canonical _Code is Poetry_ image and center image using HTML

Props @rmccue.

* Scripts: Provide the default configuration for the `test` command (#83)

* Scripts: Provide the default configuration for the `test` command
It is used in the case when the project does not have a config for Jest or Babel

* Scripts: Add tests for utils to ensure they work properly

* Add back end-of-file new line

* fix(scripts): rename script from `test-unit` to `test-unit-js` (#86)

* Chore: Update Jest dependencies (#87)

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* chore: remove `package-lock.json` files, lockfiles for apps, but not for packages

* chore: add `package-lock.json` to `gitignore`

* chore: add `package-lock=false` in new `.npmrc` files for each package

* chore: add `"npmClientArgs": ["--no-package-lock"]` to Lerna `bootstrap` command

See lerna/lerna#1235 (comment)

* Remove Lerna `npmClientArgs` option

* Hooks: Avoid validating namespace in runHooks

Unnecessary because a hook cannot be registered with an invalid hook name, so it would not pass the subsequent condition to check that a hookset with corresponding name exists.

* Hooks: Use null prototype object with truthy access

https://jsperf.com/object-create-null-vs-hasownproperty

* Hooks: Simplify return first arg logic

Even if we don't intend to return value, no harm in assigning to args[ 0 ]

* Hooks: Assign hooks current initial value in creation

* Hooks: Avoid initializing hook history if not run

* Hooks: Add baseline benchmark

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Wrap filename in backticks

* Package: Add `@wordpress/custom-templated-path-webpack-plugin` package

* chore: add` jest-preset` keyword to `jest-preset-default`

* Hooks: Fix undefined arguments on consecutive action callbacks

* Hooks: Correct CHANGELOG version to 1.1.6

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Custom Templated Path Plugin: Remove debugging statement from tests

😬

* docs: updated handbook URL

* docs: update the Browserslist example repo URL (#98)

* WordPress i18n package: Initial commit (#96)

* docs(i18n): Standardize `README.md` format

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* return a boolean from `hasHook` not the hook count

* simplify logic

* update tests to expect booleans from hasFilter/Action

* Clean up docs and return

* Add `publish:check` script to run `lerna updated`

* babel-preset-default: Remove babel-plugin-lodash (#109)

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* i18n: Support accumulatively registering additional locale data for domain (#105)

* allow for setting additional locale data for a domain accumulatively

* woops wrong object reference

* add test for accumulation of localeData

* repackage additional tests

* use more performant “in” check instead of lodash `_.has`

* use hasOwnProperty instead of in

* fix formatting for code style

* fix formatting

* use Object.assign instead of lodash.merge

* add new plural strings to tests

* simplify merging

* indent, indent

* i18n: Fix indentation

* i18n: Memoize dcnpgettext (#101)

* i18n: Memoize dcnpgettext

* i18n: Export dcnpgettext inline

* Publish

 - @wordpress/[email protected]

* Add WordCounter package (#10)

* Adding WordCounter package

* Simplifying test syntax

* export the count as default

* Creating a simpler API

* Refactor into a single function export

*  Modification based on review notes

* Complete refactor based on suggestions from @omarreiss

* Remove conditional check

* Moving each function into a new file. Exporting an object so we can use a single settings property and make the calls a little more sane

* Only importing the lodash method we need

* Using flow to chain the matchWords/matchCharacters inner function calls

* Adding readme

* Addressing some feedback on the PR

* Move to a simplier API

* Updates the README to match API changes

* Updates per review by @youknowriad

* Adds missing dockblock param

* Spacing issues

* Adds correct docblocks and fixes some whitespace issues

* Adding some whitespace as per review comment

* Add prependHTTP() to @wordpress/url (#112)

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Add a publishConfig setting to wordcount's package.json, and fix the indenting. (#114)

* Improve the publishing process documentation and error checking (#115)

* Add package: @wordpress/is-shallow-equal (#110)

* Add package: @wordpress/is-shallow-equal

* Ignore benchmark for codecov

No need to affect the codecoverage stats with a benchmarking script

* Define benchmark dependencies as devDependencies

Otherwise considered a proper required dependency from perspective of consuming project

* Add test for arrays being completely equal (#117)

* Add test for arrays being completely equal

It's a nearly useless test, but it does get is-shallow-equal to 100% test coverage
See https://codecov.io/gh/WordPress/packages/src/master/packages/is-shallow-equal/index.js#L48 for the one piece of code not currently tested.

* fix spacing

* add test for object copies

* is-shallow-equal: Fall back to strict equality for non-object-like (#116)

* Ensure inverse argument order has same test result

* is-shallow-equal: Fall back to strict equality for non-object-like

* is-shallow-equal: De-snark README.md

* is-shallow-equal: Add changelog entry for 1.0.1

* wordcount: Add changelog entry for 1.0.1

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Improve hooks docs (#121)

* Add a missing `p` in the docs remove -> removep (#120)

* Fix/wordcount whitespace only error (#123)

* Addresses error thrown when the results of matchWord or matchCharacters returns null. Includes test for the case

* Changes as per @tofumatt

* Going full ternary

* is-shallow-equal: Use implicit index.js for main entry (#124)

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Correct autop, hooks latest CHANGELOG versions

* Publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Add `@wordpress/npm-package-json-lint-config` package (#119)

* Add `@wordpress/npm-package-json-lint-config` package

* Standardize packages `package.json` format per `@wordpress/npm-package-json-lint`

* Add unused `npm-package-json-lint` rules for reference

* Update `npm-package-json-lint` to `3.0.0-alpha3`

* Add `valid-values-publishConfig` rule with `{"access": "public"}` option for _packages_ repo

* use tabs for indentation

* Update npm-package-json-lint to v3

* Update npmPackageJsonLintConfig config formatting

* Use latest `3.0.1` npm-package-json-lint release and remove `.npmpackagejsonlintrc.json`

* Use `lint:pkg-json` as the npmPkgJsonLint script task name

* fix `pretest` test script command

* Npm package.json lint config: address my own comments

* Add is-plain-object as devDependency

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add [email protected] CHANGELOG entry

* Add a custom Lerna publish commit message (#125)

* chore(release): publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]
 - @wordpress/[email protected]

* Babel preset: Enable support for async generator functions (#126)

* Babel preset: Enabled support for async generator functions

* Babel preset: Add unit tests for async generator functions

* Babel preset: Update changelog

* chore(release): publish

 - @wordpress/[email protected]
 - @wordpress/[email protected]

* chore: update `codecov` to v3, resolves all `npm audit` issues. (#127)

* Scripts: Add support for lint-pkg-json script (#128)

* Scripts: Add support for lint-pkg-json script

* Scripts: Update documentation for `lint-pkg-json` command

* Scripts: Update changelog

* chore(release): publish

 - @wordpress/[email protected]

* Count when a hook that doesn't have any handlers is run. (#134)

Fixes #133.

* chore(release): publish

 - @wordpress/[email protected]

* Jest Console: Add new matchers for console.log and console.info (#137)

* Jest Console: Add new matchers for console.log and console.info

* Jest-console: Update CHANGELOG with braking changes details

* Move packages from temporary directory to packages/

* Remove all the obsolete files from the old packages

* Synchronize package.json with the one from packages.

* Synchronize lerna.json with the one from packages

* Remove old packages build script

* Add `is-shallow-equal/benchmark` to codecov ignore

* Remove npm-run-all

* Packages: Synchronize dependencie to avoid having copies of the same libraries

* Tests: Update test config to work with local packages

* ESLint initial fixes via --fix

* Build: Make Webpack build work again :)

* Build: Fix the issue with babel makepot plugin

* Packages: Fix all linter errors

* Build: Use Lerna 3 for managing packages

It folows the setup of Lerna itself which demonstrates "the golden path of local file: specifiers at scale".
See: lerna/lerna#1307.

* Packages: Fix configuration with newly introduced packages

* Testing: Try to fix jest-console tests

* Testing: Try to fix jest-console tests

* jest-preset-default: Alphabetize dependencies

* Testing: Use toThrowError matcher for jest-console
@abrightclearweb
Copy link

Here is a list of the Classic Editor keyboard shortcuts for Mac with a note of which ones work in Gutenberg

Default shortcuts, Cmd + letter:

Letter Action Works? Letter Action Works?
u Underline yes b Bold yes
i Italic yes x Cut yes
c Copy yes v Paste yes
a Select all yes* z Undo yes
y Redo yes      

* Press once to select a block. Press twice to select all blocks.

Additional shortcuts, Ctrl + Alt + letter:

Letter Action Works? Letter Action Works?
1 Heading 1 no 2 Heading 2 no
3 Heading 3 no 4 Heading 4 no
5 Heading 5 no 6 Heading 6 no
7 Paragraph no q Blockquote no
d Strikethrough yes x Code yes
c Align center no r Align right no
l Align left no j Justify no
u Bulleted list no o Numbered list no
m Insert/edit image no s Remove link yes
z Toolbar Toggle no t Insert Read More tag no
p Insert Page Break tag no w Distraction-free writing mode no
h Keyboard Shortcuts no      

When starting a new paragraph with one of these formatting shortcuts followed by a space, the formatting will be applied automatically. Press Backspace or Escape to undo.

    Works?     Works?
* Bulleted list yes 1. Numbered list yes
- Bulleted list yes 1) Numbered list yes

The following formatting shortcuts are replaced when pressing Enter. Press Escape or the Undo button to undo.

    Works?
> Blockquote yes *
## Heading 2 yes *
### Heading 3 yes *
#### Heading 4 yes *
##### Heading 5 yes *
###### Heading 6 yes *
--- Horizontal line yes

* Must add a space after the characters

Focus shortcuts:

    Works?
Alt + F8 Inline toolbar (when an image, link or preview is selected) no
Alt + F9 Editor menu (when enabled) no
Alt + F10 Editor toolbar Brings up Sound dialog
Alt + F11 Elements path Brings up Sound dialog

To move focus to other buttons use Tab or the arrow keys. To return focus to the editor press Escape or use one of the buttons.

@abrightclearweb
Copy link

Here is a list of the Classic Editor keyboard shortcuts for Windows with a note of which ones work in Gutenberg

Default shortcuts, Ctrl + letter:

Letter Action Works? Letter Action Works?
u Underline yes b Bold yes
i Italic yes x Cut yes
c Copy yes v Paste yes
a Select all yes z Undo yes
y Redo yes      

Additional shortcuts, Shift + Alt + letter:

Letter Action Works? Letter Action Works?
1 Heading 1 no 2 Heading 2 no
3 Heading 3 no 4 Heading 4 no
5 Heading 5 no 6 Heading 6 no
7 Paragraph no q Blockquote no
d Strikethrough yes x Code yes
c Align center no r Align right no
l Align left no j Justify no
u Bulleted list no o Numbered list no
m Insert/edit image no s Remove link yes
z Toolbar Toggle no t Insert Read More tag no
p Insert Page Break tag no w Distraction-free writing mode no
h Keyboard Shortcuts no      

When starting a new paragraph with one of these formatting shortcuts followed by a space, the formatting will be applied automatically. Press Backspace or Escape to undo.

    Works?     Works?
* Bulleted list yes 1. Numbered list yes
- Bulleted list yes 1) Numbered list yes

The following formatting shortcuts are replaced when pressing Enter. Press Escape or the Undo button to undo.

    Works?
> Blockquote yes *
## Heading 2 yes *
### Heading 3 yes *
#### Heading 4 yes *
##### Heading 5 yes *
###### Heading 6 yes *
--- Horizontal line yes

* Must add a space after the characters

Focus shortcuts:

    Works?
Alt + F8 Inline toolbar (when an image, link or preview is selected) no
Alt + F9 Editor menu (when enabled) no
Alt + F10 Editor toolbar Triggers change block type
Alt + F11 Elements path no

To move focus to other buttons use Tab or the arrow keys. To return focus to the editor press Escape or use one of the buttons.

@abrightclearweb
Copy link

Just a note that the Additional shortcuts listed above

  • Ctrl + Alt + letter (Mac) or
  • Shift + Alt + letter (Windows)

will still work in the Classic block.

@bph
Copy link
Contributor

bph commented Jul 31, 2018

Great work @abrightclearweb on listing all the things that work and don't work. I counted and there are still 23 shortcuts not working with Gutenberg. For power users that's a big hick-up in their work flows.

@karmatosed @jasmussen Is there ambition to be have feature parity between classic editor and Gutenberg or is that part of the user testing, and you are waiting for feedback to decide which ones make it into Gutenberg?

@jasmussen
Copy link
Contributor Author

For the features that exist in Gutenberg that have counterparts in the classic editor, we absolutely want to make sure the shortcut keys are added. I imagine we'll ultimately end up with more keyboard shortcuts than the old editor, as there are a lot of new features. See also #8316 and #8279.

I imagine there are also features or flows in the classic editor that are different in Gutenberg and therefore might not make sense to port over. Not that I can think of an example right now.

@CalumChilds
Copy link

Can't you just keep the same shortcuts where possible?

@fr-laurentn
Copy link

fr-laurentn commented Aug 7, 2018

Hello,

I noticed that the CTRL+Y shortcut used to redo an action seems to be broken (only Ctrl+Shift+Z is working). Should I open a new ticket for that?

Or is it OK to address that issue here? (I'm quite new here)

Thanks,

@talldan
Copy link
Contributor

talldan commented Aug 10, 2018

@fr-laurentn I noticed in the codebase this seems to have been done on purpose, some details in the comment above it.

this.editor.shortcuts.remove( 'meta+y', '', 'Redo' );

@afercia
Copy link
Contributor

afercia commented Aug 10, 2018

this.editor.shortcuts.remove( 'meta+y', '', 'Redo' );

Seeing this now, I'm not fully convinced;

  • users are used to meta+y in addition to meta+shift+z
  • on Windows, Ctrl+y is standard, while Ctrl+Shift+z doesn't make much sense
  • in the classic block in Gutenberg (and in the classic editor) meta+y still works and there should be consistency across all the blocks

@fr-laurentn
Copy link

@talldan Thanks for your digging. It seems that this is not a bug.

I agree with @afercia CTRL+Y is standard to Windows users.

Should I open a new ticket?

@talldan
Copy link
Contributor

talldan commented Aug 13, 2018

@fr-laurentn a new issue would be good. Not sure that we'd want to reintroduce meta+y for Mac or Linux, but that can be open for debate on the new issue.

@fr-laurentn
Copy link

fr-laurentn commented Aug 13, 2018

@talldan FYI here's the new issue I created: #8921

@iamkingsleyf
Copy link

still does not work

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

No branches or pull requests