My approach to this was just to use a Label element and CSS. It's hacky but it works and in my world if it works it's not stupid.
So, we start on the component template:
<GridLayout rows="*">
<ListView [items]="ordersList" (itemTap)="onOrderTap($event)" class="list-group">
<ng-template let-order="item" let-odd="odd" let-even="even">
<GridLayout [class.odd]="odd" [class.even]="even" columns="auto, *, auto">
<Label class="lavatar" text="VP" style="background-color: goldenrod; color: white;"></Label>
<StackLayout col="1" class="item-text">
<Label [text]="'#' + order.number"></Label>
<Label [text]="'Order by ' + order.guest_email"></Label>
<Label [text]="order.date_placed | date:'MMMM dd yyyy'"></Label>
</StackLayout>
</GridLayout>
</ng-template>
</ListView>
</GridLayout>
The important thing here is the Label with the class "lavatar" which as the following rules:
.lavatar{ text-align: center; font-size: 20; font-weight: bold; padding: 18; border-radius: 40; border-color: salmon; border-width: 0.5; width: 64px; height: 64px; }
The border-radius is what's actually rounds the element.
Unfortunately this rule only works on "known" dimensions - width and height. For a more dynamic solution, I think you'll have to keep looking.
Settings the colors is based on the fact that CSS rules have the "cascade rule" so the final style rule applied is what's on the element. That's why the Label has a style attribute despite knowing it's in bad taste.
Oh well.