Custom dashboard widgets
-
@3dvs Think it should probably be possible to encapsulate it in an HTML file fairly easily. Only thing I would be worried about is how local storage is handled with dashboard widgets, but figure it probably won't be an issue.
Maybe Vivaldi could even get in contact with ZenQuotes to create an official widget of their own. They are fine with my free usage with attribution, but think Vivaldi's usage would probably require more.
I probably won't have a new dashboard version done for awhile. My laptop died a little over a week ago, so I have been using an old desktop pc. It has a lot of quirks that make me not really want to set up my development tools or write code on it.
Might get enough of a gap in other projects and/or enough motivation to do it sooner, but I won't promise anything.
Hopefully I will be able to get a new laptop soon. The likely model I am looking at should hopefully be released in November. New generation CPUs were launched not too long ago, so I want to wait to get a laptop with one of those or see if the discounts on last gen models are enticing enough.
-
@luetage New release for the APOD widget. I rewrote the original post with instructions. Went a bit overboard with this ^^
-
@luetage admit it, you are actually a space nerd and have found the perfect way to combine that passion with your Vivaldi hobby
This is awesome -
@luetage Do you have a clock widget?
-
@luetage You can also add a Data URLs of an html file
Here is an exampledata:text/html;base64,<html>
  <head>
    <title>Clock</title>
    <style>
      :root {
        --main-bg-color: #1e1f26;
        --main-text-color: #ccc;
      }
      * {
        box-sizing: border-box;
      }
      body {
        margin: 0;
        height: 100vh;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
        font-size: 16px;
        background-color: var(--main-bg-color);
        position: relative;
        transition: all ease 0.2s;
      }
      .clock {
        margin: 20px;
        height: calc(min(100vw, 100vh) - 40px);
        width: calc(min(100vw, 100vh) - 40px);
        display: flex;
        justify-content: center;
        align-items: center;
        background-color: var(--main-bg-color);
        background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAAGQCAYAAACAvzbMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMDY3IDc5LjE1Nzc0NywgMjAxNS8wMy8zMC0yMzo0MDo0MiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTUgKFdpbmRvd3MpIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjQwMkM2NkE1RjNDRjExRTlCQzhGRkZGNzZFRDE0RTFDIiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjQwMkM2NkE2RjNDRjExRTlCQzhGRkZGNzZFRDE0RTFDIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6NDAyQzY2QTNGM0NGMTFFOUJDOEZGRkY3NkVEMTRFMUMiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NDAyQzY2QTRGM0NGMTFFOUJDOEZGRkY3NkVEMTRFMUMiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz6dNzTWAAAT+UlEQVR42uzd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");
        background-position: center center;
        background-size: cover;
        border-radius: 50%;
        border: 4px solid var(--main-bg-color);
        box-shadow: 0 -15px 15px rgba(255, 255, 255, 0.05),
          inset 0 -15px 15px rgba(255, 255, 255, 0.05),
          0 15px 15px rgba(0, 0, 0, 0.3), inset 0 15px 15px rgba(0, 0, 0, 0.3);
        transition: all ease 0.2s;
      }
      .clock:before {
        content: "";
        height: 0.75rem;
        width: 0.75rem;
        background-color: var(--main-text-color);
        border: 2px solid var(--main-bg-color);
        position: absolute;
        border-radius: 50%;
        z-index: 1000;
        transition: all ease 0.2s;
      }
      .hour,
      .min,
      .sec {
        position: absolute;
        display: flex;
        justify-content: center;
        border-radius: 50%;
      }
      .hour {
        height: calc((min(100vw, 100vh) - 40px) * 0.5);
        width: calc((min(100vw, 100vh) - 40px) * 0.5);
      }
      .hour:before {
        content: "";
        position: absolute;
        height: 50%;
        width: 6px;
        background-color: var(--main-text-color);
        border-radius: 6px;
      }
      .min {
        height: calc((min(100vw, 100vh) - 40px) * 0.6);
        width: calc((min(100vw, 100vh) - 40px) * 0.6);
      }
      .min:before {
        content: "";
        height: 50%;
        width: 4px;
        background-color: var(--main-text-color);
        border-radius: 4px;
      }
      .sec {
        height: calc((min(100vw, 100vh) - 40px) * 0.7);
        width: calc((min(100vw, 100vh) - 40px) * 0.7);
      }
      .sec:before {
        content: "";
        height: 60%;
        width: 2px;
        background-color: #f00;
        border-radius: 2px;
      }
    </style>
  </head>
  <body>
    <div class="clock">
      <div class="hour"></div>
      <div class="min"></div>
      <div class="sec"></div>
    </div>
    <script>
      const deg = 6;
      const hour = document.querySelector(".hour");
      const min = document.querySelector(".min");
      const sec = document.querySelector(".sec");
      const setClock = () => {
        let day = new Date();
        let hh = day.getHours() * 30;
        let mm = day.getMinutes() * deg;
        let ss = day.getSeconds() * deg;
        hour.style.transform = `rotateZ(${hh + mm / 12}deg)`;
        min.style.transform = `rotateZ(${mm}deg)`;
        sec.style.transform = `rotateZ(${ss}deg)`;
      };
      setClock();
      setInterval(setClock, 1000);
    </script>
  </body>
</html>

Tool to convert https://dopiaza.org/tools/datauri/index.php
-
@tam710562 That’s a neat and straightforward way to share a widget.
-
@tam710562 Thank you.
-
@tam710562 Could you share all the code?
-
@jimmynewtron He shared all the code. It’s a data URL. Copy it and use it as webpage URL in your widget. If you want to get a hold of the original HTML code, right‐click the widget and under developer tools pick “inspect.” Switch to the sources tab and click on the data URL on the left side, there you can view/copy the HTML.
-
@luetage Thank you. It worked.
-
Still not so powerful as my mod: https://forum.vivaldi.net/topic/95430/speed-dial-widgets. It's not working now, but you can grasp some ideas: using of css-selector, resizing and scaling.
-
Binary Clock Widget
light dark Displays a simple binary clock in a widget. For information and tips how to read out the actual time I refer you to @Ruarí’s excellent blog post on the topic ☛ https://ruario.vivaldi.net/2023/11/06/reading-a-binary-watch-tips/
Installation
Use the link to download the webpage folder
binary-clock-widget.zip
. You can preview its contents by visiting https://github.com/luetage/vivaldi_modding/tree/master/binary-clock-widget first.Extract the zip file and save the folder to a location of your choice (e.g. alongside other Vivaldi backup files).
Open the dashboard, add a new webpage widget and use the path to the
binary.html
file within thebinary-clock-widget
folder as webpage URL ☛file:///full/path/to/folder/binary-clock-widget/binary.html
. Alternatively open the HTML file directly in Vivaldi and copy the address.Notes
Runs offline. Displays hours and minutes in binary format (24 hour clock). Updates once a minute and then calculates the next minute jump, instead of checking every second. This is supposed to be run as a regular size widget, you can change the widget size from the three dot menu. Automatically adapts to your Vivaldi theme when you check “Share Theme Colors” when adding the widget, otherwise it’s black on white.
History
2024.10.0 Release
️
2024.10.1 Fix minor alignment issue
2024.10.2 Update light theme
2024.10.3 Dashboard-camo support
2024.12.0 Use Vivaldi theme variables -
@luetage to simplify the installation for source code from github you can use GitHub & BitBucket HTML Preview to generate the link to the html page
-
@tam710562 This is nifty, didn’t know about it. But for the binary clock everything is done locally, they are no calls to other websites, it runs from your own device. Therefore I believe it doesn’t make sense to load the widget from a server each time.
But it isn’t much code at all; I will combine it into one HTML file and use your data URI approach for this widget, or at least provide the option. For modding purposes (theming et al.) downloading the folder gives you the source.
-
The apod widget can’t handle today’s “picture,” because none is provided. I did a small update that fixes the issue and at least displays the info and provides the link.
I f*ed up the update, didn’t really have time. It correctly shows the
noimage
default image on media type “other,” but will spit it out all the time. Anyway, I pushed a proper update and increased the version to2024.10.4
. Sorry for the confusion. I hope this works now, if not, another update will follow. -
Has anyone found a way to access the CSS variables of the Vivaldi UI, or somehow pass them into the website? It would be really great if the theme of custom webpage widgets could adapt to that of the browser.
I've just tried out the dashboard on the latest release candidate, and I'm excited to check out the modding forum once the dashboard hits stable and everyone gets their hands on it!
-
@HKayn You could maybe do that, but it would need a custom browser modification I assume; a function that sends the color variables to your widgets. I believe I would know how to do it for tabs, but widgets aren’t tabs. Prefers color scheme will give you two different themes to work with for light and dark native in CSS. Pick neutral color schemes and they should fit right in with your Vivaldi themes.
-
@luetage said in Custom dashboard widgets:
@HKayn You could maybe do that, but it would need a custom browser modification I assume; a function that sends the color variables to your widgets.
I've gone ahead and built exactly that! https://forum.vivaldi.net/topic/102173/dashboard-camo-theme-integration-for-dashboard-webpages
Turns out that webpage widgets are really just tabs.
-
Fortune Widget
light dark Displays a random fortune each time you open the dashboard.
Installation
Use the link to download the webpage folder
fortune-widget.zip
. You can preview its contents by visiting https://github.com/luetage/vivaldi_modding/tree/master/fortune-widget first.Extract the zip file and save the contents to a location of your choice in a folder called
fortune-widget
(e.g. alongside other Vivaldi backup files).Open the dashboard, add a new webpage widget, check “Share Theme Colors,” and use the path to the
fortune.html
file within thefortune-widget
folder as webpage URL ☛file:///full/path/to/folder/fortune-widget/fortune.html
. Alternatively open the HTML file directly in Vivaldi and copy the address.Notes
Runs offline. Fortunes are loaded locally from a central
data.js
file in yourfortune-widget
folder. The program comes with around 11k fortunes, sourced from https://github.com/your-fortune/your-fortune.github.io and filtered by character count. Feel free to edit the file as you see fit, but make sure to use a proper text editor, because it’s quite large. When adding your own fortunes make sure to use curly‐ instead of straight quotes. The widget will replace 2 dashes for an en‐dash, 3 dashes for en em‐dash, and converts asterisks to bold and italic just like in markdown (*italic*, **bold**
). Separate quote and author.History
2024.10.0 Release
2024.10.1 Dashboard-camo support
2024.12.0 Use Vivaldi theme variables -
@nomadic I tested the local storage. It works in widgets. One thing to note is that local storage only survives restarts, if you allow cookies for the page. Once you attempt to delete session data, even if it isn’t present, local storage will be cleared too. Making an exception for the widget in privacy settings is a way around it.