speedtest/frontend
sstidl 3a7dc31ff2
Implement the new design from #649 (#694)
* Implement fromScratch design

* Add some documentation

* enable new design in docker (no alpine yet)

* merge fixed docker images

* alpine docker added new design

* fix #685

* Implement fromScratch design

* Add some documentation

* enable new design in docker (no alpine yet)

* alpine docker added new design

* fix #685

* fix database permissions alpine, remove baby

* hide serverselector on only one server

* Update frontend/styling/server-selector.css

Co-authored-by: qodo-merge-pro-for-open-source[bot] <189517486+qodo-merge-pro-for-open-source[bot]@users.noreply.github.com>

* fix alpine image again

* adjust settings.json in entrypoint

so env vars are honored

* Update frontend/javascript/index.js

Co-authored-by: qodo-merge-for-open-source[bot] <189517486+qodo-merge-for-open-source[bot]@users.noreply.github.com>

* Add feature switch for new design via config file, URL parameters, and Docker (#742)

* Initial plan

* Add feature switch for new design with config and URL parameter support

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Improve error handling and prevent infinite redirect loops

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Update Dockerfiles and entrypoint to support design feature switch

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Update design-switch.js

Co-authored-by: qodo-free-for-open-source-projects[bot] <189517486+qodo-free-for-open-source-projects[bot]@users.noreply.github.com>

* fix: copy actions in entrypoint

* Restructure design switch to place both designs at root level

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Flatten frontend assets in Docker to eliminate frontend directory

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* fix: entrypoint settings & server-list

disable entrypoint bash debug

* add link to modern design

---------

Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>
Co-authored-by: sstidl <sstidl@users.noreply.github.com>
Co-authored-by: qodo-free-for-open-source-projects[bot] <189517486+qodo-free-for-open-source-projects[bot]@users.noreply.github.com>

* add armv7

* reformat

* Add GDPR_EMAIL environment variable for Docker deployments (#743)

* Initial plan

* Add GDPR_EMAIL environment variable for Docker deployments

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Improve GDPR_EMAIL handling with proper escaping and loop

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Refine GDPR_EMAIL processing - skip index.html and improve escaping

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Optimize GDPR_EMAIL sed commands and improve escaping

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* Clarify sed escaping comment for GDPR_EMAIL

Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

---------

Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>

* cleanup old EMAIL ENV Var

* fix: line break in html prevented sed replacement

* version 6.0.0pre1

* test: add mssql docker compose tests

* Update Speedtest screen recording link in README

* Filter unreachable servers from selector (newdesign UI) (#769)

* Filter unreachable servers from selector (newdesign UI)

* Apply suggestions from code review

Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>

* Potential fix for pull request finding

Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>

* keep // servers in list

Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>

* fix misleading comment

---------

Co-authored-by: Lumi <lumi@openclaw.local>
Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>
Co-authored-by: Stefan Stidl <sti-github@stidl.com>

* fix: server.json handling

* Use server-list.json in classic frontend by default

* Add configurable server list URLs to frontend and Docker

---------

Co-authored-by: Timendus <mail@timendus.com>
Co-authored-by: Stefan Stidl <stefan.stidl@ffg.at>
Co-authored-by: qodo-merge-pro-for-open-source[bot] <189517486+qodo-merge-pro-for-open-source[bot]@users.noreply.github.com>
Co-authored-by: qodo-merge-for-open-source[bot] <189517486+qodo-merge-for-open-source[bot]@users.noreply.github.com>
Co-authored-by: Copilot <198982749+Copilot@users.noreply.github.com>
Co-authored-by: sstidl <12804296+sstidl@users.noreply.github.com>
Co-authored-by: qodo-free-for-open-source-projects[bot] <189517486+qodo-free-for-open-source-projects[bot]@users.noreply.github.com>
Co-authored-by: Stefan Stidl <sti-github@stidl.com>
Co-authored-by: Lumi <lumi@openclaw.local>
Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>
2026-04-11 23:07:05 +02:00
..
fonts Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
images Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
javascript Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
screenshots Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
styling Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
index.html Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
README.md Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
server-list.json Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00
settings.json Implement the new design from #649 (#694) 2026-04-11 23:07:05 +02:00

LibreSpeed frontend

This is a re-implementation of the LibreSpeed user interface based on the design by fromScratch. The code that's doing the actual speed test is still the same.

Desktop

Desktop screenshot

Mobile

Mobile screenshot

How to use

Copy everything in this directory into the LibreSpeed root, next to speedtest.js and speedtest_worker.js, overwriting the index.html file that may already be there. That's it!

Configuration

In the server-list.json file you can provide a list of testing servers. If you only have a single testing server, just provide a list with one item in it, being your server. The frontend will then skip doing an automatic server selection and will not allow the user to change servers.

If you want to load the server list from a different URL, change the SPEEDTEST_SERVERS variable in index-modern.html before javascript/index.js is loaded. For example:

<script type="text/javascript">
  var SPEEDTEST_SERVERS = "https://example.com/custom-server-list.json";
</script>
<script type="text/javascript" src="javascript/index.js"></script>

You can also provide a relative URL, for example var SPEEDTEST_SERVERS = "/speedtest/servers.json";.

For more advanced applications, you can override any of the settings that are defined in speedtest_worker.js using the file settings.json. See speedtest_worker.js for documentation on the different settings (scroll down a bit to where you find the definition of the settings object).

Features

  • Shows upload and download speed and progress
  • Shows ping and jitter
  • Shows your IP address and internet service provider if the testing server supports it
  • Can handle a single testing server or a list of servers
  • Can save telemetry and share results if the hosting server supports it (set telemetry_level in settings.json)
  • Does not require any build steps; implementation is pure JS & CSS
  • Has zero dependencies

Limitations

  • This frontend relies heavily on modern browser features. It should work very well in all modern ("evergreen") browsers, but has no backwards compatibility with older browsers.

Credits

Design by fromScratch Studio - 2022, 2023 (www.fromscratch.io)

"During Hacktoberfest 2022 & 2023, fromScratch Studio took on the request for LibreSpeed redesign and UI improvements. We ran 2 design sprints one on '22 and one on '23, and produced high-fidelity screens for LibreSpeed redesign. Furthermore, this year, we produced high-fidelity screens for mobile-view as well."

-- Chris-ZoGo, https://github.com/librespeed/speedtest/issues/585

Implementation by Timendus - 2024 (https://github.com/Timendus)

"I had a couple of days of free time, and I came across the design by fromScratch. I thought it looked great, and that it deserved a good implementation, so I set out to make one. I've taken the liberty of changing a couple of details, coming up with some animations and adding a few small features, but otherwise I've tried to stay as close to the "intention" of the design as I could."

-- Timendus, https://github.com/librespeed/speedtest/pull/649