Skip to content

Commit

Permalink
Make the loading state more subtle
Browse files Browse the repository at this point in the history
 - instead of a label we show a animated gradient
  • Loading branch information
toger5 committed Nov 26, 2024
1 parent 8f9bee7 commit 88d2569
Show file tree
Hide file tree
Showing 5 changed files with 38 additions and 9 deletions.
3 changes: 1 addition & 2 deletions locales/en-GB/app.json
Original file line number Diff line number Diff line change
Expand Up @@ -191,7 +191,6 @@
"expand": "Expand",
"mute_for_me": "Mute for me",
"muted_for_me": "Muted for me",
"volume": "Volume",
"waiting_for_media": "Waiting for media..."
"volume": "Volume"
}
}
34 changes: 33 additions & 1 deletion src/tile/GridTile.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,9 @@ borders don't support gradients */
position: absolute;
z-index: -1; /* Put it below the outline */
opacity: 0; /* Hidden unless speaking */
transition: opacity ease 0.15s;
/* this only animates in one direction. In the other direction,
the background will disappear and the opacity has no effect.*/
transition: opacity ease 0.5s;
inset: calc(-1 * var(--cpd-border-width-4));
border-radius: var(--cpd-space-5x);
background-blend-mode: overlay, normal;
Expand Down Expand Up @@ -48,6 +50,11 @@ borders don't support gradients */
outline: var(--cpd-border-width-2) solid var(--cpd-color-bg-canvas-default) !important;
}

.tile.loading {
/* !important because loading border should take priority over hover */
outline: var(--cpd-border-width-2) solid var(--cpd-color-bg-canvas-default) !important;
}

.tile.handRaised::before {
background: linear-gradient(
119deg,
Expand All @@ -62,6 +69,31 @@ borders don't support gradients */
opacity: 1;
}

.tile.loading::before {
background: linear-gradient(
var(--angle),
var(--cpd-color-green-900) 0%,
var(--cpd-color-blue-200) 100%
);
opacity: 1;
animation: rotate-gradient linear 2s infinite;
}

@property --angle {
syntax: "<angle>";
inherits: false;
initial-value: 0deg;
}

@keyframes rotate-gradient {
from {
--angle: 0deg;
}
to {
--angle: 360deg;
}
}

@media (hover: hover) {
.tile:hover {
outline: var(--cpd-border-width-2) solid
Expand Down
2 changes: 2 additions & 0 deletions src/tile/GridTile.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ import {
useDisplayName,
LocalUserMediaViewModel,
RemoteUserMediaViewModel,
EncryptionStatus,
} from "../state/MediaViewModel";
import { Slider } from "../Slider";
import { MediaView } from "./MediaView";
Expand Down Expand Up @@ -145,6 +146,7 @@ const UserMediaTile = forwardRef<HTMLDivElement, UserMediaTileProps>(
className={classNames(className, styles.tile, {
[styles.speaking]: showSpeaking,
[styles.handRaised]: !showSpeaking && !!handRaised,
[styles.loading]: encryptionStatus === EncryptionStatus.Connecting,
})}
nameTagLeadingIcon={
<AudioIcon
Expand Down
3 changes: 2 additions & 1 deletion src/tile/MediaView.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -74,8 +74,9 @@ describe("MediaView", () => {
render(
<MediaView {...baseProps} video={undefined} localParticipant={false} />,
);
const tile = screen.getByTestId("videoTile");
expect(screen.getByRole("img", { name: "some name" })).toBeVisible();
expect(screen.getByText("video_tile.waiting_for_media")).toBeVisible();
expect(tile.classList).toContain("loading");

Check failure on line 79 in src/tile/MediaView.test.tsx

View workflow job for this annotation

GitHub Actions / Run vitest tests

src/tile/MediaView.test.tsx > MediaView > with no participant > shows avatar and label for remote user

AssertionError: expected [ 'media' ] to include 'loading' ❯ src/tile/MediaView.test.tsx:79:30
});
});

Expand Down
5 changes: 0 additions & 5 deletions src/tile/MediaView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -120,11 +120,6 @@ export const MediaView = forwardRef<HTMLDivElement, Props>(
/>
)}
</div>
{!video && !localParticipant && (
<div className={styles.status}>
{t("video_tile.waiting_for_media")}
</div>
)}
{/* TODO: Bring this back once encryption status is less broken */}
{/*encryptionStatus !== EncryptionStatus.Okay && (
<div className={styles.status}>
Expand Down

0 comments on commit 88d2569

Please sign in to comment.