Add separate theme option for outer popup style
This commit is contained in:
parent
1da60aae2d
commit
b086fca69f
@ -277,6 +277,7 @@ function profileOptionsCreateDefaults() {
|
|||||||
compactGlossaries: false,
|
compactGlossaries: false,
|
||||||
mainDictionary: '',
|
mainDictionary: '',
|
||||||
popupTheme: 'default',
|
popupTheme: 'default',
|
||||||
|
popupOuterTheme: 'default',
|
||||||
customPopupCss: ''
|
customPopupCss: ''
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@ class SettingsPopupPreview {
|
|||||||
this.frontend = null;
|
this.frontend = null;
|
||||||
this.apiOptionsGetOld = apiOptionsGet;
|
this.apiOptionsGetOld = apiOptionsGet;
|
||||||
this.popupShown = false;
|
this.popupShown = false;
|
||||||
|
this.themeChangeTimeout = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
static create() {
|
static create() {
|
||||||
@ -97,6 +98,13 @@ class SettingsPopupPreview {
|
|||||||
|
|
||||||
onThemeDarkCheckboxChanged(node) {
|
onThemeDarkCheckboxChanged(node) {
|
||||||
document.documentElement.classList.toggle('dark', node.checked);
|
document.documentElement.classList.toggle('dark', node.checked);
|
||||||
|
if (this.themeChangeTimeout !== null) {
|
||||||
|
clearTimeout(this.themeChangeTimeout);
|
||||||
|
}
|
||||||
|
this.themeChangeTimeout = setTimeout(() => {
|
||||||
|
this.themeChangeTimeout = null;
|
||||||
|
this.frontend.popup.updateTheme();
|
||||||
|
}, 300);
|
||||||
}
|
}
|
||||||
|
|
||||||
setText(text) {
|
setText(text) {
|
||||||
|
@ -40,6 +40,7 @@ async function formRead(options) {
|
|||||||
options.general.popupHorizontalOffset2 = parseInt($('#popup-horizontal-offset2').val(), 0);
|
options.general.popupHorizontalOffset2 = parseInt($('#popup-horizontal-offset2').val(), 0);
|
||||||
options.general.popupVerticalOffset2 = parseInt($('#popup-vertical-offset2').val(), 10);
|
options.general.popupVerticalOffset2 = parseInt($('#popup-vertical-offset2').val(), 10);
|
||||||
options.general.popupTheme = $('#popup-theme').val();
|
options.general.popupTheme = $('#popup-theme').val();
|
||||||
|
options.general.popupOuterTheme = $('#popup-outer-theme').val();
|
||||||
options.general.customPopupCss = $('#custom-popup-css').val();
|
options.general.customPopupCss = $('#custom-popup-css').val();
|
||||||
|
|
||||||
options.audio.enabled = $('#audio-playback-enabled').prop('checked');
|
options.audio.enabled = $('#audio-playback-enabled').prop('checked');
|
||||||
@ -109,6 +110,7 @@ async function formWrite(options) {
|
|||||||
$('#popup-horizontal-offset2').val(options.general.popupHorizontalOffset2);
|
$('#popup-horizontal-offset2').val(options.general.popupHorizontalOffset2);
|
||||||
$('#popup-vertical-offset2').val(options.general.popupVerticalOffset2);
|
$('#popup-vertical-offset2').val(options.general.popupVerticalOffset2);
|
||||||
$('#popup-theme').val(options.general.popupTheme);
|
$('#popup-theme').val(options.general.popupTheme);
|
||||||
|
$('#popup-outer-theme').val(options.general.popupOuterTheme);
|
||||||
$('#custom-popup-css').val(options.general.customPopupCss);
|
$('#custom-popup-css').val(options.general.customPopupCss);
|
||||||
|
|
||||||
$('#audio-playback-enabled').prop('checked', options.audio.enabled);
|
$('#audio-playback-enabled').prop('checked', options.audio.enabled);
|
||||||
|
@ -232,12 +232,24 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="popup-theme">Theme</label>
|
<div class="row">
|
||||||
|
<div class="col-xs-6">
|
||||||
|
<label for="popup-theme">Popup theme</label>
|
||||||
<select class="form-control" id="popup-theme">
|
<select class="form-control" id="popup-theme">
|
||||||
<option value="default">Light</option>
|
<option value="default">Light</option>
|
||||||
<option value="dark">Dark</option>
|
<option value="dark">Dark</option>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="col-xs-6">
|
||||||
|
<label for="popup-outer-theme">Popup shadow theme</label>
|
||||||
|
<select class="form-control" id="popup-outer-theme">
|
||||||
|
<option value="auto">Auto-detect</option>
|
||||||
|
<option value="default">Light</option>
|
||||||
|
<option value="dark">Dark</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="form-group options-advanced">
|
<div class="form-group options-advanced">
|
||||||
<label for="custom-popup-css">Custom popup CSS</label>
|
<label for="custom-popup-css">Custom popup CSS</label>
|
||||||
|
@ -85,7 +85,7 @@ class Popup {
|
|||||||
|
|
||||||
async setOptions(options) {
|
async setOptions(options) {
|
||||||
this.options = options;
|
this.options = options;
|
||||||
this.container.dataset.yomichanTheme = options.general.popupTheme;
|
this.updateTheme();
|
||||||
}
|
}
|
||||||
|
|
||||||
async show(elementRect, writingMode) {
|
async show(elementRect, writingMode) {
|
||||||
@ -270,6 +270,47 @@ class Popup {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
updateTheme() {
|
||||||
|
this.container.dataset.yomichanTheme = this.getTheme(this.options.general.popupOuterTheme);
|
||||||
|
}
|
||||||
|
|
||||||
|
getTheme(themeName) {
|
||||||
|
if (themeName === 'auto') {
|
||||||
|
const color = [255, 255, 255];
|
||||||
|
Popup.addColor(color, Popup.getColorInfo(window.getComputedStyle(document.documentElement).backgroundColor));
|
||||||
|
Popup.addColor(color, Popup.getColorInfo(window.getComputedStyle(document.body).backgroundColor));
|
||||||
|
const dark = (color[0] < 128 && color[1] < 128 && color[2] < 128);
|
||||||
|
themeName = dark ? 'dark' : 'default';
|
||||||
|
}
|
||||||
|
|
||||||
|
return themeName;
|
||||||
|
}
|
||||||
|
|
||||||
|
static addColor(target, color) {
|
||||||
|
if (color === null) { return; }
|
||||||
|
|
||||||
|
const a = color[3];
|
||||||
|
if (a <= 0.0) { return; }
|
||||||
|
|
||||||
|
const aInv = 1.0 - a;
|
||||||
|
for (let i = 0; i < 3; ++i) {
|
||||||
|
target[i] = target[i] * aInv + color[i] * a;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static getColorInfo(cssColor) {
|
||||||
|
const m = /^\s*rgba?\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(?:,\s*([\d\.]+)\s*)?\)\s*$/.exec(cssColor);
|
||||||
|
if (m === null) { return null; }
|
||||||
|
|
||||||
|
const m4 = m[4];
|
||||||
|
return [
|
||||||
|
Number.parseInt(m[1], 10),
|
||||||
|
Number.parseInt(m[2], 10),
|
||||||
|
Number.parseInt(m[3], 10),
|
||||||
|
m4 ? Math.max(0.0, Math.min(1.0, Number.parseFloat(m4))) : 1.0
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
async containsPoint(x, y) {
|
async containsPoint(x, y) {
|
||||||
for (let popup = this; popup !== null && popup.isVisible(); popup = popup.child) {
|
for (let popup = this; popup !== null && popup.isVisible(); popup = popup.child) {
|
||||||
const rect = popup.container.getBoundingClientRect();
|
const rect = popup.container.getBoundingClientRect();
|
||||||
|
Loading…
Reference in New Issue
Block a user