Add project docs, EUPL licence, and open-source licence check
Documentation & licensing:
- Add the EUPL-1.2 licence (LICENSE.md) and set the project licence; refresh
the README (name origin wink, updated feature list, documentation index).
- Add CONTRIBUTING, SECURITY, CODE_OF_CONDUCT, CHANGELOG, AUTHORS, and
THIRD_PARTY_NOTICES, plus docs/ (ARCHITECTURE, BUILD, USER_GUIDE, SHORTCUTS,
LICENSE_COMPLIANCE) and .github/ (CI workflow, issue/PR templates).
- Bring docs/FILE_FORMAT.md in line with current behaviour (code & chart
slides, per-slide TLP comment, annotation .ink.json sidecar, chart data/ CSVs).
Open-source compliance:
- Add tool/check_licenses.dart and a `make licenses` target (wired into
check-full and CI) that verifies every resolved dependency uses a recognised
open-source licence. A scan of all 151 packages and bundled assets found only
OSI-approved licences.
Charts (Fase 1.1):
- Replace the chart CSV textarea with an in-app editable data grid (editable
series/labels/values, add/remove row & column, read-only when linked).
- Centralize the linked-CSV directory name (`data/`) in a shared constant.
Also normalize formatting repo-wide with `dart format` and fix one
curly-braces lint, so `make check` and CI are green.
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-06-07 12:19:56 +02:00
|
|
|
# OciDeck — Keyboard shortcuts
|
|
|
|
|
|
|
|
|
|
`Ctrl` is shown for Windows/Linux; use `Cmd` (⌘) on macOS.
|
|
|
|
|
|
|
|
|
|
## Editor (app-wide)
|
|
|
|
|
|
|
|
|
|
| Shortcut | Action |
|
|
|
|
|
| --- | --- |
|
|
|
|
|
| `Ctrl/Cmd + O` | Open a presentation |
|
|
|
|
|
| `Ctrl/Cmd + S` | Save the active deck |
|
|
|
|
|
| `Ctrl/Cmd + Z` | Undo |
|
|
|
|
|
| `Ctrl/Cmd + Shift + Z` | Redo |
|
|
|
|
|
| `Ctrl + Y` | Redo (alternative) |
|
|
|
|
|
| `Ctrl/Cmd + H` | Find & replace |
|
Add image-library dedupe and untagged filter, UI text scaling, table paste
Image library:
- "Clean up duplicates" finds byte-identical images by md5, keeps one
file per group (preferring the most-used, then the oldest), merges
the tags/descriptions and captions of the copies, repoints slides in
open decks and in .md presentations on disk, and deletes the copies
after a confirmation that lists every group.
- A header toggle filters to images without tags/description, so it is
easy to see which ones still need attention.
- The delete warning now also lists presentations on disk that still
reference the image (marked "not open"), next to the open decks.
Editor and accessibility (already in tree):
- Interface text scaling up to 200%, keyboard-operable panel divider,
keyboard-first add-slide dialog, and screen-reader improvements.
- Paste a spreadsheet/CSV/markdown selection into a table cell to fill
the whole grid.
Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
2026-06-11 13:36:44 +02:00
|
|
|
| `Ctrl/Cmd + V` (in a table cell) | Paste a spreadsheet/CSV/markdown selection as a table (also `Shift + Insert`) |
|
|
|
|
|
| `Tab` to the panel divider, then `←` / `→` | Resize the slide panel |
|
|
|
|
|
|
|
|
|
|
In the **add-slide dialog**, `Tab` moves between the type cards, `Enter` picks
|
|
|
|
|
the focused one, and `Esc` cancels.
|
Add project docs, EUPL licence, and open-source licence check
Documentation & licensing:
- Add the EUPL-1.2 licence (LICENSE.md) and set the project licence; refresh
the README (name origin wink, updated feature list, documentation index).
- Add CONTRIBUTING, SECURITY, CODE_OF_CONDUCT, CHANGELOG, AUTHORS, and
THIRD_PARTY_NOTICES, plus docs/ (ARCHITECTURE, BUILD, USER_GUIDE, SHORTCUTS,
LICENSE_COMPLIANCE) and .github/ (CI workflow, issue/PR templates).
- Bring docs/FILE_FORMAT.md in line with current behaviour (code & chart
slides, per-slide TLP comment, annotation .ink.json sidecar, chart data/ CSVs).
Open-source compliance:
- Add tool/check_licenses.dart and a `make licenses` target (wired into
check-full and CI) that verifies every resolved dependency uses a recognised
open-source licence. A scan of all 151 packages and bundled assets found only
OSI-approved licences.
Charts (Fase 1.1):
- Replace the chart CSV textarea with an in-app editable data grid (editable
series/labels/values, add/remove row & column, read-only when linked).
- Centralize the linked-CSV directory name (`data/`) in a shared constant.
Also normalize formatting repo-wide with `dart format` and fix one
curly-braces lint, so `make check` and CI are green.
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-06-07 12:19:56 +02:00
|
|
|
|
|
|
|
|
## Fullscreen presenter
|
|
|
|
|
|
|
|
|
|
Navigation:
|
|
|
|
|
|
|
|
|
|
| Shortcut | Action |
|
|
|
|
|
| --- | --- |
|
|
|
|
|
| `→` · `Space` · `Page Down` · click | Next slide |
|
|
|
|
|
| `←` · `Page Up` | Previous slide |
|
|
|
|
|
| `Enter` | Next slide (or jump, if a number was typed) |
|
|
|
|
|
| digits, then `Enter` | Jump to that slide number |
|
|
|
|
|
| `Home` · `End` | First · last slide |
|
|
|
|
|
| `G` | Slide-grid overview (arrows + `Enter` to jump) |
|
|
|
|
|
|
|
|
|
|
View & timing:
|
|
|
|
|
|
|
|
|
|
| Shortcut | Action |
|
|
|
|
|
| --- | --- |
|
|
|
|
|
| `P` | Toggle presenter view (notes, clock, next slide) |
|
|
|
|
|
| `S` | Move the presentation to another screen |
|
|
|
|
|
| `B` · `W` | Black · white screen |
|
|
|
|
|
| `R` | Reset the elapsed-time counter |
|
|
|
|
|
| `A` | Auto-advance on/off |
|
|
|
|
|
| `L` | Loop (restart after the last slide) on/off |
|
|
|
|
|
| `M` | Advance automatically after a slide's audio finishes |
|
|
|
|
|
| `H` · `?` | Show the in-app shortcut cheatsheet |
|
|
|
|
|
|
|
|
|
|
Annotation tools:
|
|
|
|
|
|
|
|
|
|
| Shortcut | Action |
|
|
|
|
|
| --- | --- |
|
|
|
|
|
| `D` | Pen |
|
|
|
|
|
| `T` | Highlighter |
|
|
|
|
|
| `E` | Eraser |
|
|
|
|
|
| `X` | Laser pointer |
|
|
|
|
|
| `C` | Clear the current slide's annotations |
|
|
|
|
|
|
|
|
|
|
`Esc` is layered: it first puts away the active annotation tool, then clears a
|
|
|
|
|
typed slide number, then removes a black/white screen, and finally exits the
|
|
|
|
|
presentation.
|
|
|
|
|
|
|
|
|
|
> In **dual-screen** mode the keyboard stays with the laptop (presenter) window;
|
|
|
|
|
> clicks on the beamer also advance the slide.
|