summaryrefslogtreecommitdiff
path: root/webapp/src/components/hand_diagram.rs
blob: d20185195efbc0d7495491f89cbb4883de4b4c04 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use protocol::card::{Suit, sort_cards, RankOrder};
use yew::prelude::*;

use crate::components::HandProps;

pub const SUIT_ORDER: [Suit; 4] =
    [Suit::Spade, Suit::Heart, Suit::Diamond, Suit::Club];

#[function_component(HandDiagram)]
pub fn hand_diagram(props: &HandProps) -> Html {
    let mut cards = props.cards.clone();
    sort_cards(&SUIT_ORDER, RankOrder::Descending, &mut cards);
    let content: Html = SUIT_ORDER
        .iter()
        .map(|suit| {
            let cards: Html =
                cards
                .iter()
                .filter(|c| c.suit() == *suit)
                .map(|c| html! {<li>{format!("{}", c.rank())}</li>})
                .collect();

            html! {
                <ul>
                  <li>{format!("{suit}")}</li>
                  {cards}
                </ul>
            }
        })
        .collect();
    html! {
        <div class="hand-diagram">
          { content }
        </div>
    }
}