mirror of
https://github.com/zombieFox/nightTab.git
synced 2025-01-14 09:58:21 +01:00
[refactor] [design] improve theme and prevent white flash on load
This commit is contained in:
parent
f8c4d1bdb8
commit
63245d852e
@ -1,5 +1,5 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<html lang="en" style="background-color: rgba(38, 40, 49)">
|
||||
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
@ -1145,7 +1145,6 @@
|
||||
<script src="js/modal.js"></script>
|
||||
<script src="js/tip.js"></script>
|
||||
<script src="js/shade.js"></script>
|
||||
<script src="js/accent.js"></script>
|
||||
<script src="js/theme.js"></script>
|
||||
<script src="js/date.js"></script>
|
||||
<script src="js/greeting.js"></script>
|
||||
|
@ -1,78 +0,0 @@
|
||||
var accent = (function() {
|
||||
|
||||
var render = function() {
|
||||
var html = helper.e("html");
|
||||
var color = state.get().theme.accent.current;
|
||||
html.style.setProperty("--theme-accent", color.r + ", " + color.g + ", " + color.b);
|
||||
};
|
||||
|
||||
var random = function() {
|
||||
if (state.get().theme.accent.random.active) {
|
||||
var randomVal = function(min, max) {
|
||||
return Math.floor(Math.random() * (max - min) + 1) + min;
|
||||
};
|
||||
var color = {
|
||||
any: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: randomVal(0, 100),
|
||||
l: randomVal(0, 100)
|
||||
};
|
||||
},
|
||||
light: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: randomVal(50, 90),
|
||||
l: randomVal(50, 90)
|
||||
};
|
||||
},
|
||||
dark: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: randomVal(10, 50),
|
||||
l: randomVal(10, 50)
|
||||
};
|
||||
},
|
||||
pastel: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: 50,
|
||||
l: 80
|
||||
};
|
||||
},
|
||||
saturated: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: 100,
|
||||
l: 50
|
||||
};
|
||||
}
|
||||
};
|
||||
var hsl = color[state.get().theme.accent.random.style]();
|
||||
var randomColor = helper.hslToRgb({
|
||||
h: hsl.h,
|
||||
s: (hsl.s / 100),
|
||||
l: (hsl.l / 100)
|
||||
});
|
||||
helper.setObject({
|
||||
object: state.get(),
|
||||
path: "theme.accent.current",
|
||||
newValue: randomColor
|
||||
});
|
||||
helper.e(".control-theme-accent-current").value = helper.rgbToHex(randomColor);
|
||||
};
|
||||
};
|
||||
|
||||
var init = function() {
|
||||
random();
|
||||
render();
|
||||
};
|
||||
|
||||
// exposed methods
|
||||
return {
|
||||
init: init,
|
||||
render: render,
|
||||
random: random
|
||||
};
|
||||
|
||||
})();
|
@ -25,7 +25,7 @@ var control = (function() {
|
||||
path: "theme.accent.current",
|
||||
type: "color",
|
||||
func: function() {
|
||||
accent.render();
|
||||
theme.render.accent.color();
|
||||
link.clear();
|
||||
link.render.item.all();
|
||||
sortable(".link-area");
|
||||
@ -1992,7 +1992,7 @@ var control = (function() {
|
||||
type: "radio",
|
||||
func: function() {
|
||||
render();
|
||||
accent.render();
|
||||
theme.render.accent.color();
|
||||
}
|
||||
}, {
|
||||
element: helper.e(".control-theme-style-light"),
|
||||
@ -2000,7 +2000,7 @@ var control = (function() {
|
||||
type: "radio",
|
||||
func: function() {
|
||||
render();
|
||||
accent.render();
|
||||
theme.render.accent.color();
|
||||
}
|
||||
}, {
|
||||
element: helper.e(".control-theme-radius"),
|
||||
@ -2024,7 +2024,7 @@ var control = (function() {
|
||||
type: "checkbox",
|
||||
func: function() {
|
||||
dependents();
|
||||
accent.render();
|
||||
theme.render.accent.color();
|
||||
}
|
||||
}, {
|
||||
element: helper.e(".control-theme-accent-random-style-any"),
|
||||
@ -2065,8 +2065,8 @@ var control = (function() {
|
||||
element: helper.e(".control-theme-accent-randomise"),
|
||||
type: "button",
|
||||
func: function() {
|
||||
accent.random();
|
||||
accent.render();
|
||||
theme.render.accent.random();
|
||||
theme.render.accent.color();
|
||||
link.clear();
|
||||
link.render.item.all();
|
||||
sortable(".link-area");
|
||||
@ -2428,11 +2428,6 @@ var control = (function() {
|
||||
helper.addClass(html, "is-layout-scrollpastend");
|
||||
};
|
||||
};
|
||||
var _theme = function() {
|
||||
helper.removeClass(html, "is-theme-style-dark");
|
||||
helper.removeClass(html, "is-theme-style-light");
|
||||
helper.addClass(html, "is-theme-style-" + state.get().theme.style);
|
||||
};
|
||||
var _background = function() {
|
||||
if (state.get().background.image.show) {
|
||||
helper.addClass(html, "is-background-image-show");
|
||||
@ -2444,7 +2439,6 @@ var control = (function() {
|
||||
_header();
|
||||
_link();
|
||||
_layout();
|
||||
_theme();
|
||||
_background();
|
||||
};
|
||||
|
||||
|
@ -3,8 +3,8 @@ console.log("nightTab version", version.get());
|
||||
data.init();
|
||||
state.init();
|
||||
bookmarks.init();
|
||||
theme.init();
|
||||
menu.init();
|
||||
accent.init();
|
||||
link.init();
|
||||
control.init();
|
||||
greeting.init();
|
||||
@ -17,5 +17,4 @@ background.init();
|
||||
search.init();
|
||||
title.init();
|
||||
header.init();
|
||||
theme.init();
|
||||
version.init();
|
||||
|
@ -35,7 +35,7 @@ var keyboard = (function() {
|
||||
// ctrl+alt+d
|
||||
if (event.ctrlKey && event.altKey && event.keyCode == 68) {
|
||||
theme.toggle();
|
||||
control.render();
|
||||
theme.render.theme();
|
||||
control.update();
|
||||
data.save();
|
||||
};
|
||||
|
@ -21,9 +21,27 @@ var theme = (function() {
|
||||
};
|
||||
|
||||
var render = {
|
||||
theme: function() {
|
||||
_renderTheme();
|
||||
},
|
||||
radius: function() {
|
||||
_renderRadius();
|
||||
},
|
||||
accent: {
|
||||
color: function() {
|
||||
_renderAccentColor();
|
||||
},
|
||||
random: function() {
|
||||
_renderAccentRandom();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
var _renderTheme = function() {
|
||||
var html = helper.e("html");
|
||||
helper.removeClass(html, "is-theme-style-dark");
|
||||
helper.removeClass(html, "is-theme-style-light");
|
||||
helper.addClass(html, "is-theme-style-" + state.get().theme.style);
|
||||
};
|
||||
|
||||
var _renderRadius = function() {
|
||||
@ -31,7 +49,73 @@ var theme = (function() {
|
||||
html.style.setProperty("--theme-radius", state.get().theme.radius + "rem");
|
||||
};
|
||||
|
||||
var _renderAccentColor = function() {
|
||||
var html = helper.e("html");
|
||||
var color = state.get().theme.accent.current;
|
||||
html.style.setProperty("--theme-accent", color.r + ", " + color.g + ", " + color.b);
|
||||
};
|
||||
|
||||
var _renderAccentRandom = function() {
|
||||
if (state.get().theme.accent.random.active) {
|
||||
var randomVal = function(min, max) {
|
||||
return Math.floor(Math.random() * (max - min) + 1) + min;
|
||||
};
|
||||
var color = {
|
||||
any: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: randomVal(0, 100),
|
||||
l: randomVal(0, 100)
|
||||
};
|
||||
},
|
||||
light: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: randomVal(50, 90),
|
||||
l: randomVal(50, 90)
|
||||
};
|
||||
},
|
||||
dark: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: randomVal(10, 50),
|
||||
l: randomVal(10, 50)
|
||||
};
|
||||
},
|
||||
pastel: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: 50,
|
||||
l: 80
|
||||
};
|
||||
},
|
||||
saturated: function() {
|
||||
return {
|
||||
h: randomVal(0, 360),
|
||||
s: 100,
|
||||
l: 50
|
||||
};
|
||||
}
|
||||
};
|
||||
var hsl = color[state.get().theme.accent.random.style]();
|
||||
var randomColor = helper.hslToRgb({
|
||||
h: hsl.h,
|
||||
s: (hsl.s / 100),
|
||||
l: (hsl.l / 100)
|
||||
});
|
||||
helper.setObject({
|
||||
object: state.get(),
|
||||
path: "theme.accent.current",
|
||||
newValue: randomColor
|
||||
});
|
||||
helper.e(".control-theme-accent-current").value = helper.rgbToHex(randomColor);
|
||||
};
|
||||
};
|
||||
|
||||
var init = function() {
|
||||
render.theme();
|
||||
render.accent.random();
|
||||
render.accent.color();
|
||||
render.radius();
|
||||
};
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
var version = (function() {
|
||||
|
||||
var current = "3.30.9";
|
||||
var current = "3.31.0";
|
||||
|
||||
var compare = function(a, b) {
|
||||
var pa = a.split(".");
|
||||
|
@ -2,7 +2,7 @@
|
||||
"name": "nightTab",
|
||||
"short_name": "nightTab",
|
||||
"description": "A neutral new tab page accented with a chosen colour. Customise the layout, style, background and bookmarks in nightTab.",
|
||||
"version": "3.30.9",
|
||||
"version": "3.31.0",
|
||||
"manifest_version": 2,
|
||||
"chrome_url_overrides": {
|
||||
"newtab": "index.html"
|
||||
|
Loading…
Reference in New Issue
Block a user