Skip to content

Commit

Permalink
chore(orb-ui): animation for wifi qr code scanning in self-serve (#267)
Browse files Browse the repository at this point in the history
wifi qr scan animation
spinner: blue background
pearl & diamond self-serve
  • Loading branch information
fouge authored Nov 8, 2024
1 parent 149f014 commit 755c9bc
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 2 deletions.
8 changes: 8 additions & 0 deletions ui/rgb/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,9 @@ impl Argb {
pub const PEARL_RING_OPERATOR_QR_SCAN_SPINNER: Argb = Argb(None, 25, 15, 9);
pub const PEARL_RING_OPERATOR_QR_SCAN_SPINNER_OPERATOR_BASED: Argb =
Argb(None, 25, 22, 5);
/// Outer-ring color during wifi QR scans
pub const PEARL_RING_WIFI_QR_SCAN: Argb = Argb(None, 0, 5, 20);
pub const PEARL_RING_WIFI_QR_SCAN_SPINNER: Argb = Argb(None, 15, 15, 15);
/// Outer-ring color during user QR scans
pub const PEARL_RING_USER_QR_SCAN: Argb = Argb(None, 30, 20, 0);
pub const PEARL_RING_USER_QR_SCAN_SPINNER: Argb = Argb(None, 28, 25, 10);
Expand All @@ -118,6 +121,11 @@ impl Argb {
Argb(Some(Self::DIMMING_MAX_VALUE), 128, 128, 0);
pub const DIAMOND_OPERATOR_VERSIONS_OUTDATED: Argb =
Argb(Some(Self::DIMMING_MAX_VALUE), 255, 0, 0);

/// Outer-ring color during wifi QR scans
pub const DIAMOND_RING_WIFI_QR_SCAN: Argb = Argb(Some(5), 0, 15, 100);
pub const DIAMOND_RING_WIFI_QR_SCAN_SPINNER: Argb = Argb(Some(10), 60, 60, 40);

/// Outer-ring color during operator QR scans
pub const DIAMOND_RING_OPERATOR_QR_SCAN: Argb = Argb(Some(5), 77, 14, 0);
pub const DIAMOND_RING_OPERATOR_QR_SCAN_SPINNER: Argb = Argb(Some(10), 80, 50, 30);
Expand Down
15 changes: 14 additions & 1 deletion ui/src/engine/diamond.rs
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,11 @@ impl EventHandler for Runner<DIAMOND_RING_LED_COUNT, DIAMOND_CENTER_LED_COUNT> {
sound::Type::Melody(sound::Melody::InternetConnectionSuccessful),
Duration::ZERO,
)?;
self.stop_ring(LEVEL_FOREGROUND, Transition::FadeOut(0.5));
self.set_ring(
LEVEL_BACKGROUND,
animations::Static::<DIAMOND_RING_LED_COUNT>::new(Argb::OFF, None),
);
}
Event::BootComplete { api_mode } => {
self.sound.queue(
Expand Down Expand Up @@ -347,7 +352,14 @@ impl EventHandler for Runner<DIAMOND_RING_LED_COUNT, DIAMOND_CENTER_LED_COUNT> {
}
QrScanSchema::Wifi => {
self.operator_idle.no_wlan();

self.set_ring(
LEVEL_FOREGROUND,
animations::SimpleSpinner::new(
Argb::DIAMOND_RING_WIFI_QR_SCAN_SPINNER,
Some(Argb::DIAMOND_RING_WIFI_QR_SCAN),
)
.fade_in(1.5),
);
// temporarily increase the volume to ask wifi qr code
let master_volume = self.sound.volume();
self.sound.set_master_volume(40);
Expand Down Expand Up @@ -490,6 +502,7 @@ impl EventHandler for Runner<DIAMOND_RING_LED_COUNT, DIAMOND_CENTER_LED_COUNT> {
);
}
QrScanSchema::Wifi => {
self.stop_ring(LEVEL_FOREGROUND, Transition::FadeOut(0.5));
self.sound.queue(
sound::Type::Melody(sound::Melody::QrLoadSuccess),
Duration::ZERO,
Expand Down
9 changes: 8 additions & 1 deletion ui/src/engine/pearl/self_serve.rs
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,14 @@ impl Runner<PEARL_RING_LED_COUNT, PEARL_CENTER_LED_COUNT> {
}
QrScanSchema::Wifi => {
self.operator_idle.no_wlan();

self.set_ring(
LEVEL_FOREGROUND,
animations::SimpleSpinner::new(
Argb::PEARL_RING_WIFI_QR_SCAN_SPINNER,
Some(Argb::PEARL_RING_WIFI_QR_SCAN),
)
.fade_in(1.5),
);
// temporarily increase the volume to ask wifi qr code
let master_volume = self.sound.volume();
self.sound.set_master_volume(40);
Expand Down
11 changes: 11 additions & 0 deletions ui/src/simulation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,17 @@ pub async fn bootup_simulation(ui: &dyn Engine) -> Result<()> {
Ok(())
}

#[expect(dead_code)]
pub async fn wifi_qr_code_simulation(ui: &dyn Engine) {
ui.qr_scan_start(QrScanSchema::Wifi);
time::sleep(Duration::from_secs(10)).await;
ui.qr_scan_capture();
time::sleep(Duration::from_secs(2)).await;
ui.qr_scan_completed(QrScanSchema::Wifi);
time::sleep(Duration::from_secs(2)).await;
ui.network_connection_success();
}

pub async fn signup_simulation(
ui: &dyn Engine,
hardware: Hardware,
Expand Down

0 comments on commit 755c9bc

Please sign in to comment.