From 915f8f8ef5f91092b0bb3e04dadf2aca41d64f9e Mon Sep 17 00:00:00 2001 From: Illia Sheremetov Date: Mon, 31 Jul 2023 16:33:27 +0200 Subject: [PATCH 1/4] Fix (utils): fix wrong tooltip on ios --- packages/ckeditor5-utils/src/keyboard.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/ckeditor5-utils/src/keyboard.ts b/packages/ckeditor5-utils/src/keyboard.ts index 2fdbe232e52..0ad0e4a6ede 100644 --- a/packages/ckeditor5-utils/src/keyboard.ts +++ b/packages/ckeditor5-utils/src/keyboard.ts @@ -121,7 +121,7 @@ export function parseKeystroke( keystroke: string | ReadonlyArray { // Modifier keys are stored as a bit mask so extract those from the keystroke code. @@ -202,7 +202,7 @@ function getEnvKeyCode( key: string ): number { const code = getCode( key ); - return env.isMac && code == keyCodes.ctrl ? keyCodes.cmd : code; + return ( env.isMac || env.isiOS ) && code == keyCodes.ctrl ? keyCodes.cmd : code; } /** From 4d20dbfbb2d77cd5f46272f0ab787ebcc237083b Mon Sep 17 00:00:00 2001 From: Illia Sheremetov Date: Fri, 4 Aug 2023 16:45:14 +0200 Subject: [PATCH 2/4] Test (utils): adding tests --- packages/ckeditor5-utils/tests/keyboard.js | 94 ++++++++++++++++++++++ 1 file changed, 94 insertions(+) diff --git a/packages/ckeditor5-utils/tests/keyboard.js b/packages/ckeditor5-utils/tests/keyboard.js index 7b953790017..246dafb0caa 100644 --- a/packages/ckeditor5-utils/tests/keyboard.js +++ b/packages/ckeditor5-utils/tests/keyboard.js @@ -85,9 +85,11 @@ describe( 'Keyboard', () => { describe( 'parseKeystroke', () => { const initialEnvMac = env.isMac; + const initialEnviOS = env.isiOS; afterEach( () => { env.isMac = initialEnvMac; + env.isiOS = initialEnviOS; } ); describe( 'on Macintosh', () => { @@ -134,6 +136,50 @@ describe( 'Keyboard', () => { } ); } ); + describe( 'on iOS', () => { + beforeEach( () => { + env.isiOS = true; + } ); + + it( 'parses string', () => { + expect( parseKeystroke( 'ctrl+a' ) ).to.equal( 0x880000 + 65 ); + } ); + + it( 'parses string without modifier', () => { + expect( parseKeystroke( '[' ) ).to.equal( 91 ); + } ); + + it( 'allows spacing', () => { + expect( parseKeystroke( 'ctrl + a' ) ).to.equal( 0x880000 + 65 ); + } ); + + it( 'is case-insensitive', () => { + expect( parseKeystroke( 'Ctrl+A' ) ).to.equal( 0x880000 + 65 ); + } ); + + it( 'works with an array', () => { + expect( parseKeystroke( [ 'ctrl', 'a' ] ) ).to.equal( 0x880000 + 65 ); + } ); + + it( 'works with an array which contains numbers', () => { + expect( parseKeystroke( [ 'shift', 33 ] ) ).to.equal( 0x220000 + 33 ); + } ); + + it( 'works with two modifiers', () => { + expect( parseKeystroke( 'ctrl+shift+a' ) ).to.equal( 0x880000 + 0x220000 + 65 ); + } ); + + it( 'supports forced modifier', () => { + expect( parseKeystroke( 'ctrl!+a' ) ).to.equal( 0x110000 + 65 ); + } ); + + it( 'throws on unknown name', () => { + expectToThrowCKEditorError( () => { + parseKeystroke( 'foo' ); + }, 'keyboard-unknown-key', null ); + } ); + } ); + describe( 'on non–Macintosh', () => { beforeEach( () => { env.isMac = false; @@ -181,9 +227,11 @@ describe( 'Keyboard', () => { describe( 'getEnvKeystrokeText', () => { const initialEnvMac = env.isMac; + const initialEnviOS = env.isiOS; afterEach( () => { env.isMac = initialEnvMac; + env.isiOS = initialEnviOS; } ); describe( 'on Macintosh', () => { @@ -232,6 +280,52 @@ describe( 'Keyboard', () => { } ); } ); + describe( 'on iOS', () => { + beforeEach( () => { + env.isiOS = true; + } ); + + it( 'replaces CTRL with ⌘', () => { + expect( getEnvKeystrokeText( 'CTRL' ) ).to.equal( '⌘' ); + expect( getEnvKeystrokeText( 'CTRL+A' ) ).to.equal( '⌘A' ); + expect( getEnvKeystrokeText( 'ctrl+A' ) ).to.equal( '⌘A' ); + } ); + + it( 'replaces CTRL! with ⌃', () => { + expect( getEnvKeystrokeText( 'CTRL!' ) ).to.equal( '⌃' ); + expect( getEnvKeystrokeText( 'CTRL!+A' ) ).to.equal( '⌃A' ); + expect( getEnvKeystrokeText( 'ctrl!+A' ) ).to.equal( '⌃A' ); + } ); + + it( 'replaces SHIFT with ⇧', () => { + expect( getEnvKeystrokeText( 'SHIFT' ) ).to.equal( '⇧' ); + expect( getEnvKeystrokeText( 'SHIFT+A' ) ).to.equal( '⇧A' ); + expect( getEnvKeystrokeText( 'shift+A' ) ).to.equal( '⇧A' ); + } ); + + it( 'replaces ALT with ⌥', () => { + expect( getEnvKeystrokeText( 'ALT' ) ).to.equal( '⌥' ); + expect( getEnvKeystrokeText( 'ALT+A' ) ).to.equal( '⌥A' ); + expect( getEnvKeystrokeText( 'alt+A' ) ).to.equal( '⌥A' ); + } ); + + it( 'work for multiple modifiers', () => { + expect( getEnvKeystrokeText( 'CTRL+SHIFT+X' ) ).to.equal( '⌘⇧X' ); + expect( getEnvKeystrokeText( 'ALT+SHIFT+X' ) ).to.equal( '⌥⇧X' ); + } ); + + it( 'normalizes value', () => { + expect( getEnvKeystrokeText( 'ESC' ) ).to.equal( 'Esc' ); + expect( getEnvKeystrokeText( 'TAB' ) ).to.equal( 'Tab' ); + expect( getEnvKeystrokeText( 'A' ) ).to.equal( 'A' ); + expect( getEnvKeystrokeText( 'a' ) ).to.equal( 'A' ); + expect( getEnvKeystrokeText( 'CTRL+a' ) ).to.equal( '⌘A' ); + expect( getEnvKeystrokeText( 'ctrl+b' ) ).to.equal( '⌘B' ); + expect( getEnvKeystrokeText( 'CTRL+[' ) ).to.equal( '⌘[' ); + expect( getEnvKeystrokeText( 'CTRL+]' ) ).to.equal( '⌘]' ); + } ); + } ); + describe( 'on non–Macintosh', () => { beforeEach( () => { env.isMac = false; From 0c5a2c623650cd3e439d5b7e31bc4d36b881e7cf Mon Sep 17 00:00:00 2001 From: Illia Sheremetov Date: Thu, 17 Aug 2023 11:13:21 +0200 Subject: [PATCH 3/4] Test (utils): fix test --- packages/ckeditor5-utils/tests/keyboard.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/packages/ckeditor5-utils/tests/keyboard.js b/packages/ckeditor5-utils/tests/keyboard.js index 246dafb0caa..23f2440b40a 100644 --- a/packages/ckeditor5-utils/tests/keyboard.js +++ b/packages/ckeditor5-utils/tests/keyboard.js @@ -95,6 +95,7 @@ describe( 'Keyboard', () => { describe( 'on Macintosh', () => { beforeEach( () => { env.isMac = true; + env.isiOS = false; } ); it( 'parses string', () => { @@ -139,6 +140,7 @@ describe( 'Keyboard', () => { describe( 'on iOS', () => { beforeEach( () => { env.isiOS = true; + env.isMac = false; } ); it( 'parses string', () => { From 3d2e592e5289dd75e1de8e511231050be5422dfb Mon Sep 17 00:00:00 2001 From: Illia Sheremetov Date: Thu, 17 Aug 2023 11:15:17 +0200 Subject: [PATCH 4/4] Test (utils): fix test --- packages/ckeditor5-utils/tests/keyboard.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/packages/ckeditor5-utils/tests/keyboard.js b/packages/ckeditor5-utils/tests/keyboard.js index 23f2440b40a..b0ba09f5d0f 100644 --- a/packages/ckeditor5-utils/tests/keyboard.js +++ b/packages/ckeditor5-utils/tests/keyboard.js @@ -239,6 +239,7 @@ describe( 'Keyboard', () => { describe( 'on Macintosh', () => { beforeEach( () => { env.isMac = true; + env.isiOS = false; } ); it( 'replaces CTRL with ⌘', () => { @@ -285,6 +286,7 @@ describe( 'Keyboard', () => { describe( 'on iOS', () => { beforeEach( () => { env.isiOS = true; + env.isMac = false; } ); it( 'replaces CTRL with ⌘', () => {