Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(v2) Bubble Tea API #1118

Draft
wants to merge 314 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
314 commits
Select commit Hold shift + click to select a range
c47c2b9
refactor: unexport win32 input mode
aymanbagabas Aug 20, 2024
e206b36
fix: use explicit names for kitty keyboard option
aymanbagabas Aug 20, 2024
6f7f9e6
feat: expose the renderer interface
aymanbagabas Aug 19, 2024
fa03b59
feat: add custom renderer option
aymanbagabas Aug 19, 2024
c385aba
feat: add renderer Resize and InsertAbove
aymanbagabas Aug 19, 2024
ae0c273
refactor: check the initial size during Run
aymanbagabas Aug 19, 2024
53d72b4
feat: add the ability to change the renderer output
aymanbagabas Aug 20, 2024
544a715
fix: simplify instantiating a new standard renderer
aymanbagabas Aug 20, 2024
0825f61
feat: export nil renderer
aymanbagabas Aug 20, 2024
fe54df7
docs(examples): add help view to table example
meowgorithm Aug 20, 2024
a6b9970
chore(deps): go mod tidy
meowgorithm Aug 20, 2024
1f88b9e
refactor: simplify renderer interface
aymanbagabas Aug 20, 2024
9660d7d
fix: keep track of terminal capabilities and gracefully turn them off
aymanbagabas Aug 20, 2024
c9f2a56
fix: screen test
aymanbagabas Aug 21, 2024
05f8399
feat: dry setting and retrieving terminal modes
aymanbagabas Aug 21, 2024
f31a5f3
refactor: we don't care about renderer render errors
aymanbagabas Aug 21, 2024
356c649
fix(examples): update testdata
aymanbagabas Aug 21, 2024
5693515
chore(docs): edit some comments in the renderer interface
meowgorithm Aug 21, 2024
1f5a28f
feat: expose the renderer interface (#1094)
aymanbagabas Aug 21, 2024
8635fb3
fix: hide cursor if needed after restore
aymanbagabas Aug 21, 2024
fe88dd5
fix: show the cursor on exit
aymanbagabas Aug 21, 2024
f757c10
chore(deps): bump github.com/charmbracelet/x/ansi from 0.2.1 to 0.2.2…
dependabot[bot] Aug 22, 2024
55fb63f
chore(deps): go mod tidy
meowgorithm Aug 22, 2024
5df8f28
fix(examples): keys shouldn't be routed to viewport in chat example
meowgorithm Aug 22, 2024
fa69e03
fix: lint issues (#1109)
aymanbagabas Aug 22, 2024
508be2e
fix: force query the terminal bg before running any programs
aymanbagabas Aug 22, 2024
833cc78
chore: go mod tidy
aymanbagabas Aug 22, 2024
b2e983a
feat: add mode 2027 grapheme clustering stubs (#1105)
aymanbagabas Aug 23, 2024
ad68c42
feat!: make Init return the model (#1112)
aymanbagabas Aug 23, 2024
537c80b
Merge branch 'main' into v2-exp
aymanbagabas Aug 30, 2024
6e060ca
refactor!: remove backwards compatibility
aymanbagabas Aug 22, 2024
7b87642
refactor!: use key/mouse msg interfaces
aymanbagabas Aug 22, 2024
16f706a
refactor: expose key codes and define key/mouse interfaces
aymanbagabas Aug 27, 2024
e8903bb
feat!: use KeyExtended to signify more than one rune
aymanbagabas Aug 27, 2024
2f14548
docs: add godoc examples
aymanbagabas Aug 27, 2024
0c8967d
fix(kitty): only use printables
aymanbagabas Aug 28, 2024
2f6637b
fix: windows driver build
aymanbagabas Aug 29, 2024
3faa9b3
feat: use kitty report alternate keys with enhanced keyboard
aymanbagabas Aug 28, 2024
033071b
feat: export kitty/xterm/win32 input commands and messages
aymanbagabas Aug 28, 2024
9d02251
fix(key): use the key text value when keycode is multirune
aymanbagabas Aug 28, 2024
8a75439
(v2) Use KeyMsg/MouseMsg interfaces (#1111)
aymanbagabas Aug 30, 2024
85c5adc
(v2) Export different input mode commands and messages (#1119)
aymanbagabas Aug 30, 2024
0985406
Merge branch 'main' into v2-exp
aymanbagabas Sep 11, 2024
ee120d5
chore: update examples to use v2-exp
aymanbagabas Sep 12, 2024
c86cd34
Merge branch 'main' into v2-exp
aymanbagabas Sep 12, 2024
88141ed
chore: update tutorials to use v2-exp
aymanbagabas Sep 12, 2024
73773e8
feat: recognize nested sequence msgs
aymanbagabas Sep 12, 2024
0fe006d
feat: use the new renderer interface
aymanbagabas Sep 12, 2024
614aa93
fix: renderer: don't return a Cmd on update
aymanbagabas Sep 12, 2024
516b7cd
fix: renderer: nilRenderer doesn't need to be exported
aymanbagabas Sep 12, 2024
4e118e9
fix: lint issues
aymanbagabas Sep 12, 2024
4967f6b
fix: unexport standardRenderer
aymanbagabas Sep 12, 2024
9636413
fix: use safeWriter to guard writing to output
aymanbagabas Sep 12, 2024
2ad1918
chore: go mod tidy
aymanbagabas Sep 12, 2024
695fbf3
fix: only shutdown the program once
aymanbagabas Sep 12, 2024
a6725ba
fix: implement RequestCapability and unexport and remove internal mes…
aymanbagabas Sep 12, 2024
eacd930
feat(examples): add request-capability example
aymanbagabas Sep 12, 2024
ceaed4d
fix: restore terminal colors
aymanbagabas Sep 12, 2024
4fa1f06
fix: terminal colors tests
aymanbagabas Sep 12, 2024
d1827e4
fix: ignore invalid XTGETTCAP responses
aymanbagabas Sep 12, 2024
1bd66e6
fix: ignore nil terminal colors
aymanbagabas Sep 12, 2024
45222df
fix: only reset terminal colors if they're changed
aymanbagabas Sep 13, 2024
7df684a
fix: handle Kitty keyboard protocol extensions to legacy sequences
aymanbagabas Sep 16, 2024
d77a935
chore(deps): bump github.com/charmbracelet/x/ansi from 0.2.3 to 0.3.1
aymanbagabas Sep 16, 2024
3f75169
chore(deps): bump charmbracelet/x/ansi from 0.3.1 to 0.3.2
aymanbagabas Sep 16, 2024
3650670
fix: reset terminal colors on exit using osc 110/111/112
aymanbagabas Sep 16, 2024
62e46fe
fix: unexport kitty, modifyOtherKeys, and windowsInputMode options
aymanbagabas Sep 16, 2024
a26ecc5
fix: implement String() method for MouseButton type
aymanbagabas Sep 16, 2024
8b51296
feat: support terminal color profiles
aymanbagabas Sep 16, 2024
01a9fc8
feat: add colorprofile example
aymanbagabas Sep 16, 2024
f31aa40
fix: revert go.mod version change
aymanbagabas Sep 17, 2024
14cb6b5
feat!: v2: update module path to github.com/charmbracelet/bubbletea/v2
aymanbagabas Sep 18, 2024
1678d85
feat: use bubbles/v2 and bubbletea/v2 in examples and tutorials
aymanbagabas Sep 18, 2024
7cb34be
(v2) feat: combine keyboard enhancements into a nicer API (#1152)
aymanbagabas Sep 18, 2024
3274e41
docs(tutorials): upgrade tuts to v2 (#1155)
meowgorithm Sep 18, 2024
d727a8c
fix: enabling alt screen buffer should also set the cursor visibility
aymanbagabas Sep 19, 2024
a7d49d0
chore: remove deprecated
aymanbagabas Sep 19, 2024
265996c
docs: update godoc examples to return model in Init
aymanbagabas Sep 19, 2024
d815192
chore: use bubbles/v2@v2-deprecated
aymanbagabas Sep 19, 2024
09d1678
fix: don't close output writer on stopRenderer
aymanbagabas Sep 20, 2024
a039baa
fix: properly store kitty keyboard flags
aymanbagabas Sep 20, 2024
8085d33
feat: add kitty keyboard uniform key layout support
aymanbagabas Sep 20, 2024
84b68c5
feat: examples: update the print-key example to show the key text
aymanbagabas Sep 20, 2024
c53a7c9
fix: kitty: use the correct case for key text
aymanbagabas Oct 7, 2024
e812e94
fix: examples: update examples to use tea.KeyPressMsg and tea.MouseCl…
aymanbagabas Oct 11, 2024
ee16c6e
chore: drop Lip Gloss v1 lockup workaround for Lip Gloss v2 prep
meowgorithm Oct 11, 2024
792918f
feat: trace i/o to a file
aymanbagabas Oct 11, 2024
a08b8d4
fix: kitty: support faulty c0 mappings (#1161)
aymanbagabas Oct 15, 2024
e8f7e58
Fix textinputs example (#1176)
dogwaterdev1 Oct 15, 2024
8a91939
fix: kitty: correctly handle printable characters with no modifiers
aymanbagabas Oct 15, 2024
fb09ffd
chore: go mod tidy and update teatest/v2
aymanbagabas Oct 16, 2024
ecec8dc
refactor: windows: clean up, tidy and improve windows key handling
aymanbagabas Sep 20, 2024
b36937a
refactor: windows: clean up and remove redundent code
aymanbagabas Oct 14, 2024
c35932f
fix(windows): test cases on windows
aymanbagabas Oct 15, 2024
943846c
fix(windows): properly return focus events
aymanbagabas Oct 15, 2024
af4f115
chore(windows): add driver test cases
aymanbagabas Oct 15, 2024
85d716d
fix: lint issues
aymanbagabas Oct 15, 2024
bde5d1b
fix: use lf instead of crlf line endings
aymanbagabas Oct 16, 2024
5d08fe9
refactor: windows: clean up, tidy and improve windows key handling (#…
aymanbagabas Oct 16, 2024
d26972f
Merge branch 'main' into v2-exp
aymanbagabas Oct 16, 2024
2c29ed8
fix: linting issues
aymanbagabas Oct 16, 2024
ad61ed6
feat: support changing the cursor style
aymanbagabas Oct 16, 2024
d95e275
feat(examples): add cursor style example
aymanbagabas Oct 16, 2024
c928766
feat: use cellbuf for rendering
aymanbagabas Oct 10, 2024
40f9d16
chore: update cellbuf
aymanbagabas Oct 11, 2024
ff9d66c
fix(windows): we need to ensure that newline auto return is disabled
aymanbagabas Oct 11, 2024
dbd7ea6
feat: add experimental features (#1183)
aymanbagabas Oct 11, 2024
233434e
refactor: implement cell renderer screen type and perform rendering c…
aymanbagabas Oct 14, 2024
9e9c56e
feat: use image.Point instead of cellbuf.Position for cursor position
aymanbagabas Oct 15, 2024
9f6f5cd
chore: merge branch 'main' into v2-exp
aymanbagabas Oct 21, 2024
43b11c3
fix: make grapheme clustering opt-in
aymanbagabas Oct 22, 2024
e858f4a
chore: merge branch 'main' into v2-exp
aymanbagabas Oct 23, 2024
b3904a3
fix: windows: ensure the input buffer is empty
aymanbagabas Oct 21, 2024
f182f16
chore: merge branch 'main' into v2-exp
aymanbagabas Oct 23, 2024
5a027d5
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 23, 2024
baecd89
chore: merge branch 'main' into v2-exp
aymanbagabas Oct 24, 2024
a008bbf
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 24, 2024
a31857d
chore: merge branch 'main' into v2-exp
aymanbagabas Oct 24, 2024
e3caea7
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 24, 2024
08c975b
chore(deps): bump cellbuf to v0.0.1
aymanbagabas Oct 25, 2024
b51c92d
fix(renderer): reset cursor position when at phantom cell
aymanbagabas Oct 28, 2024
945617e
fix: clearing the screen should repaint the whole screen
aymanbagabas Oct 28, 2024
7d137bf
feat: update cellbuf to v0.0.2
aymanbagabas Oct 28, 2024
3bd4650
chore: use verbs in background, foreground, and window request cmd na…
meowgorithm Oct 28, 2024
86d5db1
feat: support setting cursor position (#1191)
aymanbagabas Oct 28, 2024
385d980
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 28, 2024
f7c4647
fix(renderer): mark cell as dirty only if it was set successfully
aymanbagabas Oct 28, 2024
6498624
chore: merge branch 'v2-exp' into v2-colorprofile
aymanbagabas Oct 28, 2024
026625d
feat: use colorprofile writer in standard renderer
aymanbagabas Oct 28, 2024
5c21725
chore: go mod tidy
aymanbagabas Oct 28, 2024
952b69d
fix: use ANSI256 color profile in screen_test.go
aymanbagabas Oct 28, 2024
8e99020
fix: skip test that fails due to color profile
aymanbagabas Oct 28, 2024
94b7873
feat: support terminal color profiles (#1151)
aymanbagabas Oct 29, 2024
95aa2ca
chore: merge branch 'main' into v2-exp
aymanbagabas Oct 29, 2024
250def3
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 29, 2024
162dd8e
feat: add color profile support to cell renderer
aymanbagabas Oct 29, 2024
723bdbb
fix: renderer: update color profile on message
aymanbagabas Oct 29, 2024
be159a0
chore(examples): go mod tidy
aymanbagabas Oct 29, 2024
83a84e4
refactor: move input tracing to input parser and simplify tracing
aymanbagabas Oct 29, 2024
d7790f3
chore: bump ansi to v0.4.2
aymanbagabas Oct 29, 2024
fc554e5
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 30, 2024
13a18ac
fix: refactor: move input tracing to input parser and simplify tracing
aymanbagabas Oct 30, 2024
4af7891
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 30, 2024
9f6db97
chore: bump colorprofile to v0.1.5
aymanbagabas Oct 30, 2024
5c20234
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 30, 2024
a3bec0b
chore: update colorprofile to v0.1.6
aymanbagabas Oct 31, 2024
8f2d092
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Oct 31, 2024
75327d4
fix: remove unused
aymanbagabas Oct 31, 2024
4322179
fix: windows: fix parser methods availability
aymanbagabas Oct 31, 2024
07a3c85
chore(deps): use latest Bubbles v2 at v2-exp
meowgorithm Oct 24, 2024
3e4e97f
docs(examples): add context to capabilties example
meowgorithm Oct 24, 2024
727a299
docs(examples): update credit card example for Lip Gloss v2
meowgorithm Oct 24, 2024
d7e7959
docs(examples): add context to cursor example
meowgorithm Oct 24, 2024
6f7fbb7
docs(examples): run filepicker example in the altscreen
meowgorithm Oct 24, 2024
d7b929e
docs(examples): add tiny aesthetic improvement to help example
meowgorithm Oct 24, 2024
934e392
docs(examples): update list-simple example for Lip Gloss v2
meowgorithm Oct 24, 2024
0d311d3
docs(examples): update list-fancy for Lip Gloss v2
meowgorithm Oct 25, 2024
087a675
docs(examples): minor aesthetic improvements to the prevent-quit example
meowgorithm Oct 27, 2024
bad1719
docs(examples): minor copy edit to print-key example
meowgorithm Oct 27, 2024
45bdf3d
docs(examples): add comments to sequence example
meowgorithm Oct 27, 2024
6bc247b
docs(examples): elaborate on instructions in set-terminal-color example
meowgorithm Oct 27, 2024
90bf827
docs(examples): expand on instructions in set-window-title example
meowgorithm Oct 27, 2024
894f7f0
docs(examples): fix split-editors example for Lip Gloss v2
meowgorithm Oct 27, 2024
5c83190
docs(examples): update tabs example for Lip Gloss v2
meowgorithm Oct 27, 2024
3071c58
docs(examples): minor UX improvement to the window-size example
meowgorithm Oct 27, 2024
cfc0f83
docs(examples): update paginator example for Lip Gloss v2
meowgorithm Oct 28, 2024
968efa9
docs(examples): update table-resize example for Lip Gloss v2
meowgorithm Oct 29, 2024
8121b26
docs(examples): update RequestBackgroundColor API
meowgorithm Oct 29, 2024
436d9f3
docs(examples): bump examples to current Bubbles v2-exp
meowgorithm Oct 29, 2024
ed3971d
chore(examples): use lipgloss/v2 in examples
aymanbagabas Oct 29, 2024
8dc4394
docs(examples): tiny copy edit to colorprofile example
meowgorithm Oct 31, 2024
4f70d4c
docs(examples): update for new Bubbles v2 API changes
meowgorithm Oct 31, 2024
31762e3
chore: bump ansi to v0.4.3
aymanbagabas Nov 4, 2024
265650c
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Nov 4, 2024
9f5cddf
fix: renderer: hide cursor when clearing screen
aymanbagabas Nov 4, 2024
4d16e00
refactor: use clamp function in cellRenderer.update
aymanbagabas Nov 4, 2024
2142ea6
feat: add RequestCursorPosition command
aymanbagabas Nov 5, 2024
a78f2a6
fix: remove unused max function
aymanbagabas Nov 5, 2024
9feba9c
fix: lint issues
aymanbagabas Nov 5, 2024
a2c8b38
chore: merge branch 'main' into v2-exp
aymanbagabas Nov 5, 2024
ead5503
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Nov 5, 2024
8bf66b0
feat: enable cell based renderer by default
meowgorithm Nov 6, 2024
9aab531
chore(renderer): cellRenderer is now ferociousRenderer
meowgorithm Nov 6, 2024
ec9c837
fix(lint): un-shadow variables
meowgorithm Nov 6, 2024
c66c815
chore: add internal option for using the standard renderer
meowgorithm Nov 6, 2024
65514b9
chore: fix gosec linter warnings
aymanbagabas Nov 6, 2024
7b01292
chore: merge branch 'v2-exp' into v2-renderer
aymanbagabas Nov 6, 2024
d18aee5
chore(cursor): invert SetCursorStyle blink argument (true=blink)
meowgorithm Nov 6, 2024
0b77768
fix(examples): skip simple interactive test
aymanbagabas Nov 12, 2024
1ebb164
chore: merge ferocious renderer (#1200)
aymanbagabas Nov 12, 2024
29a3c0d
chore: merge branch 'main' into v2-exp
aymanbagabas Nov 12, 2024
b7a3c35
feat: make the ferocious renderer opt-in
aymanbagabas Nov 12, 2024
8e32054
fix: renderer: deadlock when clearing screen
aymanbagabas Nov 12, 2024
56f8ccb
fix(tests): screen tests
aymanbagabas Nov 12, 2024
206067c
chore: remove log.Printf from eventLoop
aymanbagabas Nov 12, 2024
f216d98
chore: examples: use v2 alpha.2
aymanbagabas Nov 12, 2024
15ce054
feat: updating x/ansi (#1235)
caarlos0 Nov 15, 2024
7fbf91f
chore: update ansi and dependencies
aymanbagabas Nov 21, 2024
3ea1ab9
chore: examples: update lipgloss and bubbles
aymanbagabas Nov 21, 2024
1b7743e
chore: lint issues
aymanbagabas Nov 21, 2024
ee167d0
perf: renderer: optimize printing of lines above the screen
aymanbagabas Nov 26, 2024
3971222
fix: renderer: don't move the cursor when printing lines above
aymanbagabas Nov 26, 2024
a8ed961
fix: revert ee167d01fe6b ("ferocious_renderer: optimize scrolling")
aymanbagabas Nov 26, 2024
0f4cda0
fix(examples): cursor-style: cursor blink logic
aymanbagabas Dec 9, 2024
5b775d8
fix(examples): cursor-style: set the cursor position
aymanbagabas Dec 9, 2024
0806e01
refactor: use x/input
aymanbagabas Dec 10, 2024
2df9ed0
refactor: use x/input for input events
aymanbagabas Dec 10, 2024
d4add5d
chore: merge branch 'main' into v2-exp
aymanbagabas Dec 12, 2024
38ddd02
chore(examples): update chat example to use new viewport methods
aymanbagabas Dec 12, 2024
6231121
fix(examples): restore mouse motion handling in cellbuffer example
aymanbagabas Jan 7, 2025
b704152
fix: screen tests
aymanbagabas Jan 13, 2025
0cf58be
feat: use the cursed ferocious renderer
aymanbagabas Dec 9, 2024
aed1a53
chore: bump cellbuf
aymanbagabas Dec 10, 2024
c12bddd
chore: update deps
aymanbagabas Dec 12, 2024
8014f47
chore: update go.mod and go.sum
aymanbagabas Dec 12, 2024
04c0b43
refactor: use the cursed renderer for rendering and remove the standa…
aymanbagabas Dec 12, 2024
26be4d4
feat: tests: use golden files to test screen sequences
aymanbagabas Dec 12, 2024
98eed90
chore: remove unused
aymanbagabas Dec 12, 2024
3d79aff
perf: only reset mouse modes that are set
aymanbagabas Dec 12, 2024
ea8e8e7
chore: bump cellbuf
aymanbagabas Dec 12, 2024
3e7802a
fix: renderer: attempt to resolve race condition
aymanbagabas Dec 12, 2024
f343837
fix: renderer: lastFrame should be a pointer to string
aymanbagabas Dec 20, 2024
974dc31
chore: bump cellbuf to latest
aymanbagabas Dec 20, 2024
8d5202d
fix(examples): split-editors: add CursorLineNumber style
aymanbagabas Dec 20, 2024
9a23549
chore: bump cellbuf to latest main
aymanbagabas Dec 20, 2024
05ffb54
fix: send color profile message after setting it on the renderer
aymanbagabas Dec 22, 2024
777675c
feat: use hard tabs to optimize cursor movements
aymanbagabas Jan 6, 2025
f532620
fix: renderer: repaint screen after resize
aymanbagabas Jan 7, 2025
cdd901d
chore: bump cellbuf to main
aymanbagabas Jan 7, 2025
a5ff03a
fix: renderer: guard against concurrent access to screenRenderer
aymanbagabas Jan 8, 2025
534e009
fix: translate keyboard enhancements events
aymanbagabas Jan 9, 2025
65874a6
refactor: keyboard: expose type and track requested and active enhanc…
aymanbagabas Jan 9, 2025
694276a
fix(examples): print-key: update keyboard enhancements message
aymanbagabas Jan 9, 2025
6e5929b
chore: don't expose internal fields in KeyboardEnhancements
aymanbagabas Jan 9, 2025
e06652b
fix: screen tests
aymanbagabas Jan 13, 2025
ffa5bf4
chore: bump cellbuf to fix divide by zero
aymanbagabas Jan 13, 2025
e2768ff
chore: testdata: update golden files
aymanbagabas Jan 13, 2025
446de71
fix: preserve kittyFlags and modifyOtherKeys when updating enhancements
aymanbagabas Jan 13, 2025
9f70325
chore(deps): update
caarlos0 Jan 14, 2025
4f0e1e1
chore(deps): update
caarlos0 Jan 14, 2025
380db22
Merge remote-tracking branch 'origin/main' into v2-ferocious2
caarlos0 Jan 14, 2025
30a5dd4
Merge remote-tracking branch 'origin/v2-exp' into v2-ferocious2
caarlos0 Jan 14, 2025
43a5b4d
chore(merge): use the cursed renderer (#1267)
aymanbagabas Jan 14, 2025
6f40250
chore: merge branch 'v2-exp' into v2-enh-keeb
aymanbagabas Jan 15, 2025
046a5dd
chore(deps): update
caarlos0 Jan 15, 2025
bfdb8c7
fix: withFerociousRenderer is not used anymore
caarlos0 Jan 15, 2025
4ed9c0a
chore: merge: keyboard enhancements msg, expose types and track reque…
aymanbagabas Jan 16, 2025
5fa2d54
feat: add environ type and EnvMsg message (#1287)
aymanbagabas Jan 16, 2025
52bd762
feat: add RawMsg and Raw command to print raw strings to the terminal…
aymanbagabas Jan 16, 2025
57f505c
docs: add examples and godox to EnvMsg and Raw
aymanbagabas Jan 16, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
39 changes: 16 additions & 23 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ import (
"fmt"
"os"

tea "github.com/charmbracelet/bubbletea"
tea "github.com/charmbracelet/bubbletea/v2"
)
```

Expand All @@ -92,34 +92,27 @@ type model struct {
}
```

### Initialization
## Initialization

Next, we’ll define our application’s initial state. In this case, we’re defining
a function to return our initial model, however, we could just as easily define
the initial model as a variable elsewhere, too.
Next, we’ll define our application’s initial state in the `Init` method. `Init`
can return a `Cmd` that could perform some initial I/O. For now, we don't need
to do any I/O, so for the command, we'll just return `nil`, which translates to
"no command."

```go
func initialModel() model {
return model{
func (m model) Init() (tea.Model, tea.Cmd) {
m = {
// Our to-do list is a grocery list
choices: []string{"Buy carrots", "Buy celery", "Buy kohlrabi"},

// A map which indicates which choices are selected. We're using
// the map like a mathematical set. The keys refer to the indexes
// the map like a mathematical set. The keys refer to the indexes
// of the `choices` slice, above.
selected: make(map[int]struct{}),
}
}
```

Next, we define the `Init` method. `Init` can return a `Cmd` that could perform
some initial I/O. For now, we don't need to do any I/O, so for the command,
we'll just return `nil`, which translates to "no command."

```go
func (m model) Init() tea.Cmd {
// Just return `nil`, which means "no I/O right now, please."
return nil
return m, nil
}
```

Expand All @@ -140,15 +133,15 @@ tick, or a response from a server.
We usually figure out which type of `Msg` we received with a type switch, but
you could also use a type assertion.

For now, we'll just deal with `tea.KeyMsg` messages, which are automatically
sent to the update function when keys are pressed.
For now, we'll just deal with `tea.KeyPressMsg` messages, which are
automatically sent to the update function when keys are pressed.

```go
func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
switch msg := msg.(type) {

// Is it a key press?
case tea.KeyMsg:
case tea.KeyPressMsg:

// Cool, what was the actual key pressed?
switch msg.String() {
Expand All @@ -169,9 +162,9 @@ func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
m.cursor++
}

// The "enter" key and the spacebar (a literal space) toggle
// the selected state for the item that the cursor is pointing at.
case "enter", " ":
// The "enter" key and the space bar (a literal space) toggle the
// selected state for the item that the cursor is pointing at.
case "enter", "space":
_, ok := m.selected[m.cursor]
if ok {
delete(m.selected, m.cursor)
Expand Down
69 changes: 69 additions & 0 deletions clipboard.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
package tea

// ClipboardMsg is a clipboard read message event. This message is emitted when
// a terminal receives an OSC52 clipboard read message event.
type ClipboardMsg string

// String returns the string representation of the clipboard message.
func (e ClipboardMsg) String() string {
return string(e)
}

// PrimaryClipboardMsg is a primary clipboard read message event. This message
// is emitted when a terminal receives an OSC52 primary clipboard read message
// event. Primary clipboard selection is a feature present in X11 and Wayland
// only.
type PrimaryClipboardMsg string

// String returns the string representation of the primary clipboard message.
func (e PrimaryClipboardMsg) String() string {
return string(e)
}

// setClipboardMsg is an internal message used to set the system clipboard
// using OSC52.
type setClipboardMsg string

// SetClipboard produces a command that sets the system clipboard using OSC52.
// Note that OSC52 is not supported in all terminals.
func SetClipboard(s string) Cmd {
return func() Msg {
return setClipboardMsg(s)
}
}

// readClipboardMsg is an internal message used to read the system clipboard
// using OSC52.
type readClipboardMsg struct{}

// ReadClipboard produces a command that reads the system clipboard using OSC52.
// Note that OSC52 is not supported in all terminals.
func ReadClipboard() Msg {
return readClipboardMsg{}
}

// setPrimaryClipboardMsg is an internal message used to set the primary
// clipboard using OSC52.
type setPrimaryClipboardMsg string

// SetPrimaryClipboard produces a command that sets the primary clipboard using
// OSC52. Primary clipboard selection is a feature present in X11 and Wayland
// only.
// Note that OSC52 is not supported in all terminals.
func SetPrimaryClipboard(s string) Cmd {
return func() Msg {
return setPrimaryClipboardMsg(s)
}
}

// readPrimaryClipboardMsg is an internal message used to read the primary
// clipboard using OSC52.
type readPrimaryClipboardMsg struct{}

// ReadPrimaryClipboard produces a command that reads the primary clipboard
// using OSC52. Primary clipboard selection is a feature present in X11 and
// Wayland only.
// Note that OSC52 is not supported in all terminals.
func ReadPrimaryClipboard() Msg {
return readPrimaryClipboardMsg{}
}
121 changes: 121 additions & 0 deletions color.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
package tea

import (
"image/color"

"github.com/charmbracelet/x/input"
)

// backgroundColorMsg is a message that requests the terminal background color.
type backgroundColorMsg struct{}

// RequestBackgroundColor is a command that requests the terminal background color.
func RequestBackgroundColor() Msg {
return backgroundColorMsg{}
}

// foregroundColorMsg is a message that requests the terminal foreground color.
type foregroundColorMsg struct{}

// RequestForegroundColor is a command that requests the terminal foreground color.
func RequestForegroundColor() Msg {
return foregroundColorMsg{}
}

// cursorColorMsg is a message that requests the terminal cursor color.
type cursorColorMsg struct{}

// RequestCursorColor is a command that requests the terminal cursor color.
func RequestCursorColor() Msg {
return cursorColorMsg{}
}

// setBackgroundColorMsg is a message that sets the terminal background color.
type setBackgroundColorMsg struct{ color.Color }

// SetBackgroundColor is a command that sets the terminal background color.
func SetBackgroundColor(c color.Color) Cmd {
return func() Msg {
return setBackgroundColorMsg{c}
}
}

// setForegroundColorMsg is a message that sets the terminal foreground color.
type setForegroundColorMsg struct{ color.Color }

// SetForegroundColor is a command that sets the terminal foreground color.
func SetForegroundColor(c color.Color) Cmd {
return func() Msg {
return setForegroundColorMsg{c}
}
}

// setCursorColorMsg is a message that sets the terminal cursor color.
type setCursorColorMsg struct{ color.Color }

// SetCursorColor is a command that sets the terminal cursor color.
func SetCursorColor(c color.Color) Cmd {
return func() Msg {
return setCursorColorMsg{c}
}
}

// ForegroundColorMsg represents a foreground color message. This message is
// emitted when the program requests the terminal foreground color with the
// [RequestForegroundColor] Cmd.
type ForegroundColorMsg struct{ color.Color }

// String returns the hex representation of the color.
func (e ForegroundColorMsg) String() string {
return input.ForegroundColorEvent(e).String()
}

// IsDark returns whether the color is dark.
func (e ForegroundColorMsg) IsDark() bool {
return input.ForegroundColorEvent(e).IsDark()
}

// BackgroundColorMsg represents a background color message. This message is
// emitted when the program requests the terminal background color with the
// [RequestBackgroundColor] Cmd.
//
// This is commonly used in [Update.Init] to get the terminal background color
// for style definitions. For that you'll want to call
// [BackgroundColorMsg.IsDark] to determine if the color is dark or light. For
// example:
//
// func (m Model) Init() (Model, Cmd) {
// return m, RequestBackgroundColor()
// }
//
// func (m Model) Update(msg Msg) (Model, Cmd) {
// switch msg := msg.(type) {
// case BackgroundColorMsg:
// m.styles = newStyles(msg.IsDark())
// }
// }
type BackgroundColorMsg struct{ color.Color }

// String returns the hex representation of the color.
func (e BackgroundColorMsg) String() string {
return input.BackgroundColorEvent(e).String()
}

// IsDark returns whether the color is dark.
func (e BackgroundColorMsg) IsDark() bool {
return input.BackgroundColorEvent(e).IsDark()
}

// CursorColorMsg represents a cursor color change message. This message is
// emitted when the program requests the terminal cursor color.
type CursorColorMsg struct{ color.Color }

// String returns the hex representation of the color.
func (e CursorColorMsg) String() string {
return input.CursorColorEvent(e).String()
}

// IsDark returns whether the color is dark.
func (e CursorColorMsg) IsDark() bool {
return input.CursorColorEvent(e).IsDark()
}
56 changes: 14 additions & 42 deletions commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ import (
//
// Example:
//
// func (m model) Init() Cmd {
// return tea.Batch(someCommand, someOtherCommand)
// func (m model) Init() (Model, Cmd) {
// return m, tea.Batch(someCommand, someOtherCommand)
// }
func Batch(cmds ...Cmd) Cmd {
var validCmds []Cmd //nolint:prealloc
Expand Down Expand Up @@ -78,9 +78,9 @@ type sequenceMsg []Cmd
// })
// }
//
// func (m model) Init() Cmd {
// func (m model) Init() (Model, Cmd) {
// // Start ticking.
// return tickEvery()
// return m, tickEvery()
// }
//
// func (m model) Update(msg Msg) (Model, Cmd) {
Expand Down Expand Up @@ -132,9 +132,9 @@ func Every(duration time.Duration, fn func(time.Time) Msg) Cmd {
// })
// }
//
// func (m model) Init() Cmd {
// func (m model) Init() (Model, Cmd) {
// // Start ticking.
// return doTick()
// return m, doTick()
// }
//
// func (m model) Update(msg Msg) (Model, Cmd) {
Expand All @@ -157,44 +157,16 @@ func Tick(d time.Duration, fn func(time.Time) Msg) Cmd {
}
}

// Sequentially produces a command that sequentially executes the given
// commands.
// The Msg returned is the first non-nil message returned by a Cmd.
//
// func saveStateCmd() Msg {
// if err := save(); err != nil {
// return errMsg{err}
// }
// return nil
// }
//
// cmd := Sequentially(saveStateCmd, Quit)
//
// Deprecated: use Sequence instead.
func Sequentially(cmds ...Cmd) Cmd {
return func() Msg {
for _, cmd := range cmds {
if cmd == nil {
continue
}
if msg := cmd(); msg != nil {
return msg
}
}
return nil
}
}

// setWindowTitleMsg is an internal message used to set the window title.
type setWindowTitleMsg string

// SetWindowTitle produces a command that sets the terminal title.
//
// For example:
//
// func (m model) Init() Cmd {
// func (m model) Init() (Model, Cmd) {
// // Set title.
// return tea.SetWindowTitle("My App")
// return m, tea.SetWindowTitle("My App")
// }
func SetWindowTitle(title string) Cmd {
return func() Msg {
Expand All @@ -204,12 +176,12 @@ func SetWindowTitle(title string) Cmd {

type windowSizeMsg struct{}

// WindowSize is a command that queries the terminal for its current size. It
// delivers the results to Update via a [WindowSizeMsg]. Keep in mind that
// WindowSizeMsgs will automatically be delivered to Update when the [Program]
// starts and when the window dimensions change so in many cases you will not
// need to explicitly invoke this command.
func WindowSize() Cmd {
// RequestWindowSize is a command that queries the terminal for its current
// size. It delivers the results to Update via a [WindowSizeMsg]. Keep in mind
// that WindowSizeMsgs will automatically be delivered to Update when the
// [Program] starts and when the window dimensions change so in many cases you
// will not need to explicitly invoke this command.
func RequestWindowSize() Cmd {
return func() Msg {
return windowSizeMsg{}
}
Expand Down
Loading
Loading