DEVELOPMENT ENVIRONMENT

~liljamo/deck-builder

ref: 266a4f354ad61f6acba8a12409aff529887b7c55 deck-builder/client/src/plugins/menu/ui/register.rs -rw-r--r-- 1.9 KiB
266a4f35Jonni Liljamo chore(client): fmt, clippy, cleanup 1 year, 5 months ago
                                                                                
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/*
 * This file is part of laurelin_client
 * Copyright (C) 2023 Jonni Liljamo <jonni@liljamo.com>
 *
 * Licensed under GPL-3.0-only.
 * See LICENSE for licensing information.
 */

use bevy::prelude::*;
use bevy_egui::egui;

use crate::{plugins::RegisterCallEvent, util::egui::password};

use super::{MenuData, MenuUIState};

pub fn view(
    ui: &mut egui::Ui,
    data: &mut MenuData,
    register_ev_w: &mut EventWriter<RegisterCallEvent>,
) {
    ui.horizontal(|ui| {
        ui.label("Username:");
        ui.text_edit_singleline(&mut data.register_username)
    });
    ui.horizontal(|ui| {
        ui.label("Email:");
        ui.text_edit_singleline(&mut data.register_email)
    });
    ui.horizontal(|ui| {
        ui.label("Password:");
        ui.add(password(&mut data.register_password));
    });
    ui.horizontal(|ui| {
        ui.label("Confirm password:");
        ui.add(password(&mut data.register_password_confirm));
    });

    if !data.error.is_empty() {
        ui.label(egui::RichText::new(&data.error).color(egui::Color32::RED));
    }

    ui.add_enabled_ui(
        data.register_password == data.register_password_confirm,
        |ui| {
            ui.with_layout(egui::Layout::right_to_left(egui::Align::TOP), |ui| {
                if ui.button("Register").clicked() {
                    data.error.clear();
                    data.ui_state = MenuUIState::Loading;

                    register_ev_w.send(RegisterCallEvent {
                        username: data.register_username.clone(),
                        email: data.register_email.clone(),
                        password: data.register_password.clone(),
                    });
                }
            });
        },
    );

    ui.vertical_centered(|ui| {
        ui.label("I have an account:");
        if ui.link("Login").clicked() {
            data.ui_state = MenuUIState::Login;
        }
    });
}