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

refactor(table): use lipgloss table for rendering #617

Draft
wants to merge 29 commits into
base: master
Choose a base branch
from

Conversation

bashbunni
Copy link
Member

@bashbunni bashbunni commented Sep 16, 2024

Still very wip - just opening a draft PR here to document the process. This change should fix a lot of open issues with the table bubble

TODO

  • This change needs the Height fix on the Lip Gloss table to work properly. (charmbracelet/lipgloss@a5492bc) need to make a new release that includes the fix before merging this.

  • fix YOffset

  • remove proposal.org from this PR

  • re-review API changes

@bashbunni
Copy link
Member Author

I think this is done... There are some outstanding PRs on lipgloss with bugs found during the process. You can test it out interactively in this Bubble Tea PR. Do not commit the changes to go.mod or go.sum, they are needed for validation, but won't be necessary when the changes to Lip Gloss are merged.

PRs on lipgloss
charmbracelet/lipgloss#377
charmbracelet/lipgloss#373
charmbracelet/lipgloss#372

Some great next steps would be to test these changes against existing table issues to see if they persist now that we've delegated the rendering to lipgloss

Probably still needs a bit of a tidy too to make sure I haven't left a whole bunch of TODOs in there 😅 Will mark it ready for review once that's done

@bashbunni
Copy link
Member Author

bashbunni commented Sep 25, 2024

Okay, this is nearly ready for review. I did find another bug with text alignment that should be addressed before merging (on the test-issues-with-lg-table branch that will have tests from reported table issues). I haven't pushed it to remote yet as I'll debug that locally.

image

There are also some TODOs I've kept in here for the code review so it's clear where I might be feeling uncertain.

Edit: the alignment issue is only happening with bubbles, not with my lipgloss branch or master (lipgloss)... Weird thing is the truncation is all happening on the lipgloss side, so still need to figure that out 🤔

@bashbunni
Copy link
Member Author

Right truncation from bubbles table (margins)

The issue above happens when the cell styles have margins. When you remove margins from the styling, it doesn't happen anymore. This shows that it's likely that the bubbles table is passing these styles along to the lipgloss table, but the rendered result is being truncated on the right rather than taking the alignment into account.

Weird truncation behaviour when table width is fixed

image

	t.Run("right-aligned text with fixed width table", func(t *testing.T) {
		s := DefaultStyles()
		s.Selected = s.Selected.Align(lipgloss.Right)
		s.Cell = s.Cell.Align(lipgloss.Right)
		biscuits := New(
			WithColumns([]Column{
				{Title: "Name", Width: 25},
				{Title: "Country of Origin", Width: 16},
				{Title: "Dunk-able", Width: 12},
			}),
			WithRows([]Row{
				{"Chocolate Digestives", "UK", "Yes"},
				{"Tim Tams", "Australia", "No"},
				{"Hobnobs", "UK", "Yes"},
			}),
			WithStyles(s),
		)
		biscuits.SetWidth(30)
		t.Logf("\n%s", ansi.Strip(biscuits.View()))
	})

In this case, the Cell style doesn't have margins set anymore.

@bashbunni
Copy link
Member Author

I'm able to reproduce the row truncation issue in lipgloss' table when I set a margin, so will work on fixing that outside of this PR, then hopefully this should be good to go

@bashbunni
Copy link
Member Author

TODOs:

  • scroll down behaviour should only update offset when we're on the last element (ask team)
  • expose lipgloss border API stuff
  • header BorderForeground not working (not sure if this is lip gloss? other styles are working fine in the bubble...

Need to decide on what feels good to work with. I think it might be better to actually specify the styles in a lipgloss table and use that to style the bubbles table? Copying the lipgloss table api to the bubble feels weird.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
1 participant