Skip to content

Commit

Permalink
Support >=1 download buttons per-OS & use to fix macOS M1/Intel
Browse files Browse the repository at this point in the history
  • Loading branch information
CAM-Gerlach committed Feb 8, 2024
1 parent 8300511 commit 1248fd7
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 33 deletions.
4 changes: 2 additions & 2 deletions assets/static/css/custom_styles.css
Original file line number Diff line number Diff line change
Expand Up @@ -129,9 +129,9 @@
/*** Download button formatting ***/

#section-download-buttons .content-button {
margin-bottom: 0;
margin-bottom: 1em;
margin-top: 0;
min-width: 380px;
min-width: 460px;
}

@media screen and (max-width: 480px) {
Expand Down
93 changes: 62 additions & 31 deletions assets/static/js/custom_scripts.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,27 +4,45 @@
"use strict";

/* Top-level variables */
const buttonData = {
win: {
text: "Download for Windows",
icon: ["fab", "fa-windows"],
url: "https://github.com/spyder-ide/spyder/releases/latest/download/Spyder_64bit_full.exe",
},
mac: {
text: "Download for macOS",
icon: ["fab", "fa-apple"],
url: "https://github.com/spyder-ide/spyder/releases/latest/download/Spyder.dmg",
},
linux: {
text: "Download for Linux (Anaconda)",
icon: ["fab", "fa-linux"],
url: "https://www.anaconda.com/download/",
},
other: {
text: "Download Spyder",
icon: ["fas", "fa-download"],
url: "https://github.com/spyder-ide/spyder/releases/latest",
},
const buttonsData = {
win: [
{
id: "download-windows",
text: "Download for Windows",
icon: ["fab", "fa-windows"],
url: "https://github.com/spyder-ide/spyder/releases/latest/download/Spyder_64bit_full.exe",
},
],
mac: [
{
id: "download-mac-m1",
text: "Download for macOS (M1)",
icon: ["fab", "fa-apple"],
url: "https://github.com/spyder-ide/spyder/releases/latest/download/Spyder_arm64.dmg",
},
{
id: "download-mac-intel",
text: "Download for macOS (Intel)",
icon: ["fab", "fa-apple"],
url: "https://github.com/spyder-ide/spyder/releases/latest/download/Spyder_x86_64.dmg",
},
],
linux: [
{
id: "download-linux",
text: "Download for Linux (Anaconda)",
icon: ["fab", "fa-linux"],
url: "https://www.anaconda.com/download/",
},
],
other: [
{
id: "download-other",
text: "Download Spyder",
icon: ["fas", "fa-download"],
url: "https://github.com/spyder-ide/spyder/releases/latest",
},
],
};

/* Helper functions */
Expand Down Expand Up @@ -52,24 +70,37 @@
}

// Get the button data corresponding to the current OS
function getButtonData() {
function getButtonsData() {
const osName = getOSName();
return buttonData[osName];
return buttonsData[osName];
}

/* Main functions */

// Setup download button based on current OS
function setupDownloadButton(downloadButton) {
const buttonData = getButtonData();
downloadButton.href = buttonData.url;
downloadButton.getElementsByClassName("download-text")[0].textContent =
// Create the download button nodes from a prototype
function createDownloadButton(templateButton, buttonData) {
const newButton = templateButton.cloneNode(true);
newButton.id = buttonData.id;
newButton.href = buttonData.url;
newButton.getElementsByClassName("download-text")[0].textContent =
buttonData.text;
for (const icon of buttonData.icon) {
downloadButton
newButton
.getElementsByClassName("download-os-icon")[0]
.classList.add(icon);
}
return newButton;
}

/* Main functions */

// Set up download button based on current OS
function setupDownloadButton(downloadButton) {
const downloadButtonContainer = document.createElement("div");
downloadButtonContainer.id = "download-buttons-container";
for (const buttonData of getButtonsData()) {
const newButton = createDownloadButton(downloadButton, buttonData);
downloadButtonContainer.appendChild(newButton);
}
downloadButton.replaceWith(downloadButtonContainer);
}

/* Fire events */
Expand Down

0 comments on commit 1248fd7

Please sign in to comment.