Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
0c06efe
remove startup animation
camillobruni Oct 14, 2025
54dc3c7
back to rain
camillobruni Oct 15, 2025
d4f1b08
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 22, 2025
4d42ec9
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 22, 2025
3626407
Merge branch 'main' of github.com:camillobruni/JetStream into 2025-10…
camillobruni Oct 22, 2025
d362da1
revert
camillobruni Oct 22, 2025
e2c1870
enable animation without startDelay
camillobruni Oct 22, 2025
b578b11
rename
camillobruni Oct 22, 2025
74ccb99
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 22, 2025
3c52814
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 22, 2025
e0971d1
refactor
camillobruni Oct 23, 2025
86d95d1
update
camillobruni Oct 23, 2025
b074b9d
remove debug timeout
camillobruni Oct 23, 2025
cea65b8
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 23, 2025
33bdf3a
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 23, 2025
8cd220e
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 27, 2025
b241611
wip
camillobruni Oct 27, 2025
8b2846b
faster animation
camillobruni Oct 27, 2025
db30420
fix
camillobruni Oct 27, 2025
591842d
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Oct 30, 2025
81df890
update css
camillobruni Oct 30, 2025
84102c1
more css cleanup
camillobruni Oct 30, 2025
79e418d
Merge branch 'main' into 2025-10-14_simpler_startup
camillobruni Dec 10, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 25 additions & 17 deletions JetStreamDriver.js
Original file line number Diff line number Diff line change
Expand Up @@ -217,10 +217,7 @@ class Driver {
// the global `fileLoader` cache.
this.blobDataCache = { };
this.loadCache = { };
this.counter = { };
this.counter.loadedResources = 0;
this.counter.totalResources = 0;
this.counter.failedPreloadResources = 0;
this.counter = { loadedResources: 0, totalResources: 0, failedPreloadResources: 0 };
}

async start() {
Expand Down Expand Up @@ -324,7 +321,6 @@ class Driver {
}
summaryHtml += "</div>";
const summaryElement = document.getElementById("result-summary");
summaryElement.classList.add("done");
summaryElement.innerHTML = summaryHtml;
summaryElement.onclick = displayCategoryScores;
statusElement.innerHTML = "";
Expand Down Expand Up @@ -357,7 +353,7 @@ class Driver {
}
}

prepareBrowserUI() {
async prepareBrowserUI() {
let text = "";
for (const benchmark of this.benchmarks)
text += benchmark.renderHTML();
Expand All @@ -370,6 +366,27 @@ class Driver {
if (e.key === "Enter")
JetStream.start();
});

document.body.classList.add("ready");
const statusElement = document.getElementById("status");
statusElement.innerHTML = `<a href="javascript:JetStream.start()" class="button">Start Test</a>`;

await this.waitForBrowserUIStartupAnimation();

statusElement.addEventListener("click", (e) => {
e.preventDefault();
JetStream.start();
return false;
}, { once: true});
}


async waitForBrowserUIStartupAnimation() {
if (!JetStreamParams.isDefault)
return
const cssValue = window.getComputedStyle(document.body).getPropertyValue("--startup-animation-duration");
const startupAnimationDuration = parseInt(cssValue.split("ms")[0])
await new Promise((resolve) => setTimeout(resolve, startupAnimationDuration));
}

reportError(benchmark, error) {
Expand Down Expand Up @@ -401,7 +418,7 @@ class Driver {
await this.prefetchResources();
this.benchmarks.sort((a, b) => a.plan.name.toLowerCase() < b.plan.name.toLowerCase() ? 1 : -1);
if (isInBrowser)
this.prepareBrowserUI();
await this.prepareBrowserUI();
this.isReady = true;
if (isInBrowser) {
globalThis.dispatchEvent(new Event("JetStreamReady"));
Expand Down Expand Up @@ -445,15 +462,6 @@ class Driver {
}

JetStream.loadCache = { }; // Done preloading all the files.

const statusElement = document.getElementById("status");
statusElement.classList.remove('loading');
statusElement.innerHTML = `<a href="javascript:JetStream.start()" class="button">Start Test</a>`;
statusElement.onclick = () => {
statusElement.onclick = null;
JetStream.start();
return false;
}
}

resultsObject(format = "run-benchmark") {
Expand Down Expand Up @@ -1057,7 +1065,7 @@ class Benchmark {
updateCounter() {
const counter = JetStream.counter;
++counter.loadedResources;
const statusElement = document.getElementById("status");
const statusElement = document.getElementById("status-counter");
statusElement.innerHTML = `Loading ${counter.loadedResources} of ${counter.totalResources} ...`;
}

Expand Down
15 changes: 10 additions & 5 deletions index.html
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,9 @@
}

async function initialize() {
const bodyClassList = document.body.classList;
if (!JetStreamParams.isDefault) {
bodyClassList.remove("animate");
showNonDefaultParams();
}
if (globalThis.allIsGood) {
Expand All @@ -60,16 +62,17 @@
} catch (e) {
globalThis.allIsGood = false;
console.error(e);
} finally {
bodyClassList.remove("loading");
}
}
if (!globalThis.allIsGood) {
bodyClassList.add('error');
let statusElement = document.getElementById("status");
statusElement.classList.remove('loading');
statusElement.classList.add('error');
statusElement.innerHTML = "<h2>ERROR</h2><p>Errors were encountered during page load. Refusing to run a partial benchmark suite.</p>";
}
}

function showNonDefaultParams() {
document.body.classList.add("nonDefaultParams");
const body = document.querySelector("#non-standard-params-table tbody");
Expand All @@ -87,7 +90,7 @@
<script src="JetStreamDriver.js"></script>

</head>
<body onload="initialize()">
<body onload="initialize()" class="loading animate">
<h1 class="logo">
<div id="jetstreams">
<a href="index.html" class="logo-image">JetStream 3</a>
Expand Down Expand Up @@ -116,7 +119,9 @@ <h2>Non-standard Parameters</h2>
<p class="summary" id="mode-description"></p>

<div id="result-summary"></div>
<div id="status" class="loading">Loading Benchmark...</div>
<div id="status">
<div id="status-counter">Loading Benchmark...</div>
</div>

<div id="results"></div>
</main>
Expand Down
62 changes: 42 additions & 20 deletions resources/JetStream.css
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
--benchmark-done-result-color: #4A4A4A;
--gap: 3rem;
--width: 200px;
--startup-animation-duration: 500ms;
}

html,
Expand All @@ -64,6 +65,7 @@ body {
background-size: 100vw;
padding-bottom: 0px;
background-image: url('clouds.svg');
padding-bottom: 0px;
overflow-y: hidden;
height: 100%;
}
Expand Down Expand Up @@ -175,25 +177,43 @@ img {
background-position: center;
background-image: url('JetStream3Logo.svg');
color: transparent;
animation: swingin 350ms ease-out forwards;
will-change: transform, opacity;
height: 75px;
}

.loading.animate .logo .logo-image {
animation: swingin var(--startup-animation-duration) ease-out forwards;
will-change: transform, opacity;
animation-delay: 50ms;
}

.ready .logo .logo-image {
animation: none;
opacity: 1;
}

#jetstreams {
background-image: url('jetstreams.svg');
background-repeat: no-repeat;
background-size: contain;
background-position: center;
padding: 2rem 0;
margin: -2rem 0;
background-image: url("jetstreams-static.svg");
}


#jetstreams svg {
width: 100%;
max-height: 120px;
}

.animate #jetstreams {
background-image: url("jetstreams.svg");
transition: background-image var(--startup-animation-duration) ease-in-out;
}
.ready #jetstreams {
background-image: url("jetstreams-static.svg") !important;
}

#magic {
position: absolute;
top: -900px;
Expand All @@ -215,8 +235,14 @@ article,
.summary {
max-width: 70rem;
margin: 0 auto 0 auto;
}

.loading.animate .summary {
opacity: 0;
animation: fadein 0.5s ease-in-out forwards;
}

article, .loading.animate .summary {
animation: fadein var(--startup-animation-duration) ease-in-out forwards;
animation-delay: 200ms;
}

Expand Down Expand Up @@ -302,17 +328,18 @@ a.button {
user-select: none;
}

a.button {
animation: fadein 500ms ease-in forwards, scaledown 500ms ease-in forwards;
.animate a.button {
animation: fadein var(--startup-animation-duration) ease-in forwards, scaledown var(--startup-animation-duration) ease-in forwards;
opacity: 0;
}


#status label,
.button:hover {
background-image: none;
}

#status.loading {
.loading #status-counter {
position: absolute;
top: 0;
left: 0;
Expand All @@ -331,7 +358,7 @@ a.button {
user-select: none;
}

#status.error {
.error #status {
max-width: 70rem;
margin: 0 auto 1rem;
}
Expand Down Expand Up @@ -386,14 +413,13 @@ a.button {
justify-content: space-around;
gap: var(--gap);
margin: 0 calc(var(--gap) * -1) 0 calc(-var(--gap) * -1);
animation: fadein 500ms ease-out forwards;
opacity: 0;
overflow-y: auto;
flex: 1;
padding-bottom: var(--gap);
box-sizing: border-box;
}


.benchmark {
position: relative;
flex: 1;
Expand All @@ -406,6 +432,12 @@ a.button {
scroll-margin-bottom: 20vh;
}

.animate .benchmark {
animation: fadein var(--startup-animation-duration) ease-in forwards;
opacity: 0;
}


.benchmark .result.detail {
display: none;
}
Expand Down Expand Up @@ -593,16 +625,6 @@ dt:target {
}
}

@keyframes shine {
0% {
background-position: -1200px center;
}

100% {
background-position: 100vw center;
}
}

@keyframes swingin {
from {
opacity: 0;
Expand Down
18 changes: 18 additions & 0 deletions resources/jetstreams-static.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
18 changes: 9 additions & 9 deletions resources/jetstreams.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading