Im trying to think how to do this with html elements.

There is nothing special about the colors, so I don’t need to make them images.
Do note that the text is right aligned. Also, the color bar goes up to the text from the left.
So this could be implemented by having the text float right with background color white, and a div with the background color set right next to it (and then a clear).
Or instead of floats, I can do text align-right and get a similar effect.
Here is the kicker.
I’m using a javascript library (shouldn’t matter which one) to create an animation. The animation is the bars shrink to the left, and end up like so:

The problem with the float or text-align methods are that too many values have to be changed to transition between the two states. The javascript animation effects tend to want to change a couple predefined values, like width or font-size. In order to transfer from picture 1 to picture 2 using the float or text-align methods, I must remove the floating/text-align then set the width of the bar color, but that doesn’t work if I want to keep the javascript overhead minimal for such a simple task.
I’ve tried absolute positioning/widths, but I can’t get anything to make the text right aligned AND have the bars meet at the same point on the left.
I’m hoping maybe I’m just blind of a simple solution, but as I see it, I need one element that has the text positioned to the right somehow, and an element that takes up as much room possible beside it for the color… AND the element that has the color should be able to take a width, while having the text follow beside it.
Thank you.
Here’s my attempt. Note: to the horror of some anti-table zealots this does use tables. Floats just can’t do “take up all available space” like tables can.
I thought of a non-tables way of doing it that works pretty well, so here it is: