Arabic IME character joining and RTL direction issues in Safari
OS: macOS 14.0 · Device: Desktop or Laptop Any · Browser: Safari 17.0
Open case →Scenario
Arabic and Hebrew use right-to-left direction and contextual letter forms. During composition, joining rules, bidi isolation, and Safari vs Firefox may disagree—caret position and composed text can diverge from visual order.
Arabic and Hebrew use right-to-left direction and contextual letter forms. During composition, joining rules, bidi isolation, and Safari vs Firefox may disagree—caret position and composed text can diverge from visual order.
dir="rtl" and mixed-direction spans inside contenteditable interact with IME pipelines that were often tested primarily on LTR Latin/CJK.
Misplaced caret, wrong glyph order, or selection that does not match user expectations.
Visual view of how this scenario connects to its concrete cases and environments. Nodes can be dragged and clicked.
Each row is a concrete case for this scenario, with a dedicated document and playground.
| Case | OS | Device | Browser | Keyboard | Status |
|---|---|---|---|---|---|
| ce-0179-arabic-ime-character-joining-safari | macOS 14.0 | Desktop or Laptop Any | Safari 17.0 | Arabic (IME) | draft |
| ce-0207-hebrew-ime-rtl-composition-firefox | Windows 11 | Desktop or Laptop Any | Firefox 120.0 | Hebrew (IME) | draft |
This matrix shows which browser and OS combinations have documented cases for this scenario. Click on a cell to view the specific case.
| Browser | Windows | macOS |
|---|---|---|
| Firefox | — | |
| Safari | — |
This scenario affects multiple languages. Cases are grouped by language/input method below.
OS: macOS 14.0 · Device: Desktop or Laptop Any · Browser: Safari 17.0
Open case →OS: Windows 11 · Device: Desktop or Laptop Any · Browser: Firefox 120.0
Open case →Other scenarios that share similar tags or category.
Escape typically cancels IME composition or closes the candidate window. In Edge, Firefox, and other engines, timing and whether partial text remains in the DOM differ—Arabic and Korean IME cases show cross-browser variance.
If the user switches focus to another field, button, or nested contenteditable while Korean (or other) IME composition is active, browsers differ on whether composition is committed, cancelled, or leaves orphan state. Chrome, Safari, and Firefox do not agree; mobile adds more variance.
Tab moves focus by default. During IME composition, Tab may cancel composition, cycle candidates, or be captured by the editor for indentation—behavior differs for Chinese, Thai, and Safari vs Firefox.
Japanese kanji conversion and Chinese character selection depend on the IME candidate window. Delays, wrong ordering, or Safari-specific lag can cause users to commit the wrong character or see candidates that do not match the underlying buffer—especially under load or in complex layouts.
Some browsers and keyboards emit duplicate composition-related input or beforeinput events—especially iOS Safari dictation paths and certain Android keyboards—so naive handlers that insert text on every input may double characters or corrupt state.
Have questions, suggestions, or want to share your experience? Join the discussion below.