Commit de0e9b8
authored
feat: add reader keyboard support on iOS and tvOS (#731)
## Problem
Reader keyboard support was limited to macOS even though iPad, iPhone,
and Apple TV can all be used with external keyboards. The help overlay
also shared settings across reader types, and the initial UIKit
responder handling introduced two iOS regressions: sheet presentation
could trigger AttributeGraph cycle warnings, and EPUB keyboard shortcuts
could stop responding after toggling controls.
## Approach
This PR introduces shared reader keyboard command models and routes iOS
and tvOS key events through a UIKit bridge while keeping the existing
macOS command integration. The keyboard help overlay is available across
supported reader platforms, auto-shows only when appropriate, and uses
per-reader configuration where needed. On iOS, responder updates are
deferred off the SwiftUI update path and then refreshed asynchronously
so the reader can recover keyboard focus without reintroducing the cycle
warning.
## Scope
- Add iOS and tvOS keyboard shortcut support for DIVINA reader
navigation and controls
- Extend the keyboard help overlay and auto-show behavior across DIVINA,
EPUB, and PDF readers
- Add independent EPUB and PDF keyboard help preferences while
preserving DIVINA settings
- Refactor reader command state and handlers into platform-neutral types
- Avoid iOS AttributeGraph cycles by deferring UIKit first responder
changes outside SwiftUI updates
- Restore EPUB keyboard shortcut responsiveness after toggling controls
on iOS
- Bump build version to 3991 parent b6fd537 commit de0e9b8
48 files changed
Lines changed: 1475 additions & 788 deletions
File tree
- KMReader.xcodeproj
- KMReader
- Core/Storage
- Features
- Auth
- ViewModels
- Views
- Book/Views
- Browse/Views
- Collection/Views
- Dashboard/Views
- History/Views
- Offline
- Services
- Views
- OneShot
- ReadList/Views
- Reader/Views
- Epub
- PageImage
- Pdf
- Sheets
- Series/Views
- Server
- Settings
- Components
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
438 | 438 | | |
439 | 439 | | |
440 | 440 | | |
441 | | - | |
| 441 | + | |
442 | 442 | | |
443 | 443 | | |
444 | 444 | | |
| |||
496 | 496 | | |
497 | 497 | | |
498 | 498 | | |
499 | | - | |
| 499 | + | |
500 | 500 | | |
501 | 501 | | |
502 | 502 | | |
| |||
556 | 556 | | |
557 | 557 | | |
558 | 558 | | |
559 | | - | |
| 559 | + | |
560 | 560 | | |
561 | 561 | | |
562 | 562 | | |
| |||
590 | 590 | | |
591 | 591 | | |
592 | 592 | | |
593 | | - | |
| 593 | + | |
594 | 594 | | |
595 | 595 | | |
596 | 596 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
545 | 545 | | |
546 | 546 | | |
547 | 547 | | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
548 | 560 | | |
549 | 561 | | |
550 | 562 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
8 | | - | |
| 8 | + | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
16 | | - | |
| 16 | + | |
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
297 | 297 | | |
298 | 298 | | |
299 | 299 | | |
300 | | - | |
| 300 | + | |
301 | 301 | | |
302 | 302 | | |
303 | 303 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
209 | 209 | | |
210 | 210 | | |
211 | 211 | | |
212 | | - | |
| 212 | + | |
213 | 213 | | |
214 | 214 | | |
215 | 215 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
88 | 88 | | |
89 | 89 | | |
90 | 90 | | |
91 | | - | |
| 91 | + | |
92 | 92 | | |
93 | 93 | | |
94 | 94 | | |
| |||
239 | 239 | | |
240 | 240 | | |
241 | 241 | | |
242 | | - | |
| 242 | + | |
243 | 243 | | |
244 | 244 | | |
245 | 245 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
148 | 148 | | |
149 | 149 | | |
150 | 150 | | |
151 | | - | |
| 151 | + | |
152 | 152 | | |
153 | 153 | | |
154 | 154 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
83 | 83 | | |
84 | 84 | | |
85 | 85 | | |
86 | | - | |
| 86 | + | |
87 | 87 | | |
88 | 88 | | |
89 | 89 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
90 | 90 | | |
91 | 91 | | |
92 | 92 | | |
93 | | - | |
| 93 | + | |
94 | 94 | | |
95 | 95 | | |
96 | 96 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
321 | 321 | | |
322 | 322 | | |
323 | 323 | | |
324 | | - | |
| 324 | + | |
325 | 325 | | |
326 | 326 | | |
327 | 327 | | |
| |||
0 commit comments