# feat(i18n): Hebrew locale + full RTL support ## Summary This PR adds full Hebrew (he) locale support to the UI, including a complete translation of all user-facing strings and comprehensive RTL layout support across all components. ## What was done ### Hebrew translation - Full translation of all i18n message files for the `he` locale (17 translation files) - Registered the language in the i18n system and the language picker ### RTL support - Automatic direction detection (`dir="rtl"`) when Hebrew is selected - Replaced physical CSS properties (`left`/`right`) with logical equivalents (`inline-start`/`inline-end`) across the project - Fixed resize direction, file path alignment, and textarea padding - Fixed navigation button positioning in textarea for RTL - Fixed scrollbar direction in RTL - Fixed code block direction and selector alignment - Fixed Monaco editor direction in the file viewer - Auto-detect text direction in reasoning block (`dir="auto"` + `unicode-bidi: plaintext`) ### Adapted components - `session-layout` — sidebar and resize handle - `prompt-input` — text direction and buttons - `message-base` — message blocks and reasoning - `message-timeline` — timeline bar - `right-panel` — right side panel - `tool-call` — tool call display - `settings-screen` — settings page - `selector` — selection component - `instance-shell` — main shell ## New files ``` packages/ui/src/lib/i18n/messages/he/ advancedSettings.ts app.ts commands.ts dialogs.ts filesystem.ts folderSelection.ts index.ts instance.ts loadingScreen.ts logs.ts markdown.ts messaging.ts remoteAccess.ts session.ts settings.ts time.ts toolCall.ts ``` ## Suggested testing - Switch language to Hebrew and verify all strings are translated - Verify RTL layout is correct across all screens (session, settings, file viewer) - Verify that English text inside a reasoning block is displayed LTR - Switch back to English and verify everything returns to LTR --------- Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com> Co-authored-by: Shantur Rathore <i@shantur.com>
59 lines
1.2 KiB
CSS
59 lines
1.2 KiB
CSS
.virtual-follow-list-shell {
|
|
display: flex;
|
|
flex-direction: column;
|
|
flex: 1;
|
|
min-height: 0;
|
|
position: relative;
|
|
width: 100%;
|
|
}
|
|
|
|
.message-stream {
|
|
flex: 1;
|
|
min-height: 0;
|
|
overflow-y: auto;
|
|
background-color: var(--surface-base);
|
|
color: inherit;
|
|
|
|
/* Scrolling optimizations */
|
|
overscroll-behavior-y: contain;
|
|
/* Prevents scroll chaining to parent elements */
|
|
will-change: scroll-position;
|
|
/* GPU acceleration hint for smoother scrolling */
|
|
-webkit-overflow-scrolling: touch;
|
|
/* Momentum scrolling on iOS */
|
|
|
|
/* Prevent browser scroll anchoring fighting our virtualization compensation. */
|
|
overflow-anchor: none;
|
|
|
|
/* Scrollbar styling */
|
|
scrollbar-gutter: stable;
|
|
}
|
|
|
|
.virtual-follow-list-overlay {
|
|
position: absolute;
|
|
inset: 0;
|
|
pointer-events: none;
|
|
z-index: 10;
|
|
/* Ensure it doesn't affect layout at all */
|
|
height: 0;
|
|
overflow: visible;
|
|
}
|
|
|
|
.virtual-follow-list-overlay > * {
|
|
pointer-events: auto;
|
|
}
|
|
|
|
.virtual-follow-list-controls-container {
|
|
position: absolute;
|
|
bottom: calc(var(--space-md) + env(safe-area-inset-bottom, 0px));
|
|
inset-inline-end: var(--space-md);
|
|
z-index: 20;
|
|
}
|
|
|
|
.message-stream-placeholder {
|
|
display: block;
|
|
width: 100%;
|
|
position: relative;
|
|
background-color: transparent;
|
|
}
|