mirror of
https://github.com/wukko/cobalt.git
synced 2024-11-18 06:09:58 +00:00
7.0.1: ui tweaks
- fixed streamable downloads in safari - added background blur to popup backdrop - reduced shadow blur for popups - fixed content going out of corners in picker
This commit is contained in:
parent
2038050a2d
commit
5541acee88
3 changed files with 23 additions and 11 deletions
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"name": "cobalt",
|
"name": "cobalt",
|
||||||
"description": "save what you love",
|
"description": "save what you love",
|
||||||
"version": "7.0",
|
"version": "7.0.1",
|
||||||
"author": "wukko",
|
"author": "wukko",
|
||||||
"exports": "./src/cobalt.js",
|
"exports": "./src/cobalt.js",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
--glass-lite: rgba(25, 25, 25, 0.98);
|
--glass-lite: rgba(25, 25, 25, 0.98);
|
||||||
--subbackground: rgb(10, 10, 10);
|
--subbackground: rgb(10, 10, 10);
|
||||||
--background: rgb(0, 0, 0);
|
--background: rgb(0, 0, 0);
|
||||||
|
--background-backdrop: rgba(0, 0, 0, 0.5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@media (prefers-color-scheme: light) {
|
@media (prefers-color-scheme: light) {
|
||||||
|
@ -42,6 +43,7 @@
|
||||||
--glass-lite: rgba(230, 230, 230, 0.98);
|
--glass-lite: rgba(230, 230, 230, 0.98);
|
||||||
--subbackground: rgb(240, 240, 240);
|
--subbackground: rgb(240, 240, 240);
|
||||||
--background: rgb(255, 255, 255);
|
--background: rgb(255, 255, 255);
|
||||||
|
--background-backdrop: rgba(255, 255, 255, 0.5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
[data-theme="dark"] {
|
[data-theme="dark"] {
|
||||||
|
@ -57,6 +59,7 @@
|
||||||
--glass-lite: rgba(25, 25, 25, 0.98);
|
--glass-lite: rgba(25, 25, 25, 0.98);
|
||||||
--subbackground: rgb(10, 10, 10);
|
--subbackground: rgb(10, 10, 10);
|
||||||
--background: rgb(0, 0, 0);
|
--background: rgb(0, 0, 0);
|
||||||
|
--background-backdrop: rgba(0, 0, 0, 0.5);
|
||||||
}
|
}
|
||||||
[data-theme="light"] {
|
[data-theme="light"] {
|
||||||
--accent: rgb(25, 25, 25);
|
--accent: rgb(25, 25, 25);
|
||||||
|
@ -64,13 +67,14 @@
|
||||||
--accent-subtext: rgb(110, 110, 110);
|
--accent-subtext: rgb(110, 110, 110);
|
||||||
--accent-hover: rgb(230, 230, 230);
|
--accent-hover: rgb(230, 230, 230);
|
||||||
--accent-hover-elevated: rgb(215, 215, 215);
|
--accent-hover-elevated: rgb(215, 215, 215);
|
||||||
--accent-hover-transparent: rgba(215, 215, 215, 0.5);
|
--accent-hover-transparent: rgba(219, 219, 219, 0.5);
|
||||||
--accent-button: rgb(225, 225, 225);
|
--accent-button: rgb(225, 225, 225);
|
||||||
--accent-button-elevated: rgb(210, 210, 210);
|
--accent-button-elevated: rgb(210, 210, 210);
|
||||||
--glass: rgba(230, 230, 230, 0.85);
|
--glass: rgba(230, 230, 230, 0.85);
|
||||||
--glass-lite: rgba(230, 230, 230, 0.98);
|
--glass-lite: rgba(230, 230, 230, 0.98);
|
||||||
--subbackground: rgb(240, 240, 240);
|
--subbackground: rgb(240, 240, 240);
|
||||||
--background: rgb(255, 255, 255);
|
--background: rgb(255, 255, 255);
|
||||||
|
--background-backdrop: rgba(255, 255, 255, 0.5);
|
||||||
}
|
}
|
||||||
html,
|
html,
|
||||||
body {
|
body {
|
||||||
|
@ -371,7 +375,7 @@ button:active,
|
||||||
max-height: 95%;
|
max-height: 95%;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
transform: translate(-50%,-48%)scale(.95);
|
transform: translate(-50%,-48%)scale(.95);
|
||||||
box-shadow: 0 0 40px 0 var(--accent-hover-transparent);
|
box-shadow: 0 0 20px 0 var(--accent-hover-transparent);
|
||||||
}
|
}
|
||||||
.popup.visible {
|
.popup.visible {
|
||||||
visibility: visible;
|
visibility: visible;
|
||||||
|
@ -388,16 +392,18 @@ button:active,
|
||||||
height: 100%;
|
height: 100%;
|
||||||
z-index: 998;
|
z-index: 998;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
background-color: var(--background);
|
background: var(--background-backdrop);
|
||||||
}
|
}
|
||||||
#popup-backdrop.visible {
|
#popup-backdrop.visible {
|
||||||
visibility: visible;
|
visibility: visible;
|
||||||
opacity: 0.5;
|
opacity: 1;
|
||||||
transition: opacity 130ms ease-in-out;
|
transition: opacity .13s ease-in-out;
|
||||||
|
backdrop-filter: blur(7px);
|
||||||
|
-webkit-backdrop-filter: blur(7px);
|
||||||
}
|
}
|
||||||
.popup.small {
|
.popup.small {
|
||||||
width: 20%;
|
width: 20%;
|
||||||
box-shadow: 0px 0px 80px 0px var(--accent-hover);
|
box-shadow: 0px 0px 60px 0px var(--accent-hover);
|
||||||
border: var(--accent-highlight) solid 0.15rem;
|
border: var(--accent-highlight) solid 0.15rem;
|
||||||
padding: 1.7rem;
|
padding: 1.7rem;
|
||||||
transform: translate(-50%,-50%)scale(.95);
|
transform: translate(-50%,-50%)scale(.95);
|
||||||
|
@ -803,11 +809,14 @@ button:active,
|
||||||
align-items: center;
|
align-items: center;
|
||||||
padding-top: calc(env(safe-area-inset-top) + 1rem);
|
padding-top: calc(env(safe-area-inset-top) + 1rem);
|
||||||
}
|
}
|
||||||
.no-transparency .glass-bkg {
|
.no-transparency .glass-bkg,
|
||||||
background: var(--glass-lite);
|
.no-transparency #popup-backdrop {
|
||||||
backdrop-filter: none;
|
backdrop-filter: none;
|
||||||
-webkit-backdrop-filter: none;
|
-webkit-backdrop-filter: none;
|
||||||
}
|
}
|
||||||
|
.no-transparency .glass-bkg {
|
||||||
|
background: var(--glass-lite);
|
||||||
|
}
|
||||||
.no-animation .popup,
|
.no-animation .popup,
|
||||||
.no-animation #popup-backdrop {
|
.no-animation #popup-backdrop {
|
||||||
transition: none;
|
transition: none;
|
||||||
|
@ -896,7 +905,8 @@ button:active,
|
||||||
[type=checkbox] {
|
[type=checkbox] {
|
||||||
border-radius: 3px / 4px;
|
border-radius: 3px / 4px;
|
||||||
}
|
}
|
||||||
.popup {
|
.popup,
|
||||||
|
.scrollable #popup-content {
|
||||||
border-radius: 8px / 9px;
|
border-radius: 8px / 9px;
|
||||||
}
|
}
|
||||||
#popup-header {
|
#popup-header {
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
const ua = navigator.userAgent.toLowerCase();
|
const ua = navigator.userAgent.toLowerCase();
|
||||||
const isIOS = ua.match("iphone os");
|
const isIOS = ua.match("iphone os");
|
||||||
const isMobile = ua.match("android") || ua.match("iphone os");
|
const isMobile = ua.match("android") || ua.match("iphone os");
|
||||||
|
const isSafari = ua.match("safari/");
|
||||||
const isFirefox = ua.match("firefox/");
|
const isFirefox = ua.match("firefox/");
|
||||||
const isOldFirefox = ua.match("firefox/") && ua.split("firefox/")[1].split('.')[0] < 103;
|
const isOldFirefox = ua.match("firefox/") && ua.split("firefox/")[1].split('.')[0] < 103;
|
||||||
|
|
||||||
const version = 33;
|
const version = 33;
|
||||||
const regex = new RegExp(/https:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()!@:%_\+.~#?&\/\/=]*)/);
|
const regex = new RegExp(/https:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()!@:%_\+.~#?&\/\/=]*)/);
|
||||||
const notification = `<div class="notification-dot"></div>`;
|
const notification = `<div class="notification-dot"></div>`;
|
||||||
|
@ -412,7 +414,7 @@ async function download(url) {
|
||||||
let jp = await res.json();
|
let jp = await res.json();
|
||||||
if (jp.status === "continue") {
|
if (jp.status === "continue") {
|
||||||
changeDownloadButton(2, '>>>');
|
changeDownloadButton(2, '>>>');
|
||||||
if (isMobile) {
|
if (isMobile || isSafari) {
|
||||||
window.location.href = j.url;
|
window.location.href = j.url;
|
||||||
} else window.open(j.url, '_blank');
|
} else window.open(j.url, '_blank');
|
||||||
setTimeout(() => { changeButton(1) }, 2500);
|
setTimeout(() => { changeButton(1) }, 2500);
|
||||||
|
|
Loading…
Reference in a new issue