mirror of
https://github.com/we-promise/sure.git
synced 2026-04-19 12:04:08 +00:00
* feat: Add Brand Fetch logo link for logos * docs: brand fetch integration docs * Document CLIENT_ID location? Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Signed-off-by: Juan José Mata <jjmata@jjmata.com> --------- Signed-off-by: Juan José Mata <jjmata@jjmata.com> Co-authored-by: Vincent Teo <vinteo@gmail.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>
57 lines
2.3 KiB
Plaintext
57 lines
2.3 KiB
Plaintext
<%# locals: (holding:) %>
|
|
|
|
<%= turbo_frame_tag dom_id(holding) do %>
|
|
<div class="grid grid-cols-12 items-center text-primary text-sm font-medium p-4">
|
|
<div class="col-span-4 flex items-center gap-4">
|
|
<% if Setting.brand_fetch_client_id.present? %>
|
|
<%= image_tag "https://cdn.brandfetch.io/#{holding.ticker}/icon/fallback/lettermark/w/40/h/40?c=#{Setting.brand_fetch_client_id}", class: "w-9 h-9 rounded-full", loading: "lazy" %>
|
|
<% elsif holding.security.logo_url.present? %>
|
|
<%= image_tag holding.security.logo_url, class: "w-9 h-9 rounded-full", loading: "lazy" %>
|
|
<% else %>
|
|
<%= render DS::FilledIcon.new(variant: :text, text: holding.name, size: "md", rounded: true) %>
|
|
<% end %>
|
|
<div class="space-y-0.5">
|
|
<%= link_to holding.name, holding_path(holding), data: { turbo_frame: :drawer }, class: "hover:underline" %>
|
|
|
|
<% if holding.amount %>
|
|
<%= tag.p holding.ticker, class: "text-secondary text-xs uppercase" %>
|
|
<% else %>
|
|
<%= render "missing_price_tooltip" %>
|
|
<% end %>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-2 flex justify-end items-center gap-2">
|
|
<% if holding.weight %>
|
|
<%= render "shared/progress_circle", progress: holding.weight %>
|
|
<%= tag.p number_to_percentage(holding.weight, precision: 1) %>
|
|
<% else %>
|
|
<%= tag.p "--", class: "text-secondary mb-5" %>
|
|
<% end %>
|
|
</div>
|
|
|
|
<div class="col-span-2 text-right">
|
|
<%= tag.p format_money holding.avg_cost %>
|
|
<%= tag.p t(".per_share"), class: "font-normal text-secondary" %>
|
|
</div>
|
|
|
|
<div class="col-span-2 text-right">
|
|
<% if holding.amount_money %>
|
|
<%= tag.p format_money holding.amount_money %>
|
|
<% else %>
|
|
<%= tag.p "--", class: "text-secondary" %>
|
|
<% end %>
|
|
<%= tag.p t(".shares", qty: number_with_precision(holding.qty, precision: 1)), class: "font-normal text-secondary" %>
|
|
</div>
|
|
|
|
<div class="col-span-2 text-right">
|
|
<% if holding.trend %>
|
|
<%= tag.p format_money(holding.trend.value), style: "color: #{holding.trend.color};" %>
|
|
<%= tag.p "(#{number_to_percentage(holding.trend.percent, precision: 1)})", style: "color: #{holding.trend.color};" %>
|
|
<% else %>
|
|
<%= tag.p "--", class: "text-secondary mb-4" %>
|
|
<% end %>
|
|
</div>
|
|
</div>
|
|
<% end %>
|