123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- // Bing Wallpaper GNOME extension
- // Copyright (C) 2017-2023 Michael Carroll
- // This extension is free software: you can redistribute it and/or modify
- // it under the terms of the GNU Lesser General Public License as published by
- // the Free Software Foundation, either version 3 of the License, or
- // (at your option) any later version.
- // See the GNU General Public License, version 3 or later for details.
- // Based on GNOME shell extension NASA APOD by Elia Argentieri https://github.com/Elinvention/gnome-shell-extension-nasa-apod
- // This code based on https://github.com/PRATAP-KUMAR/Control_Blur_Effect_On_Lock_Screen
- // and https://github.com/sunwxg/gnome-shell-extension-unlockDialogBackground
- import St from 'gi://St';
- import * as UnlockDialog from 'resource:///org/gnome/shell/ui/unlockDialog.js';
- import * as Config from 'resource:///org/gnome/shell/misc/config.js';
- var _updateBackgroundEffects = UnlockDialog.UnlockDialog.prototype._updateBackgroundEffects;
- var _showClock = UnlockDialog.UnlockDialog.prototype._showClock;
- var _showPrompt = UnlockDialog.UnlockDialog.prototype._showPrompt;
- var shellVersionMajor = parseInt(Config.PACKAGE_VERSION.split('.')[0]);
- var shellVersionMinor = parseInt(Config.PACKAGE_VERSION.split('.')[1]);
- var shellVersionPoint = parseInt(Config.PACKAGE_VERSION.split('.')[2]);
- // default BWP mild blur
- var BWP_BLUR_SIGMA = 2;
- var BWP_BLUR_BRIGHTNESS = 55;
- // GNOME defaults
- var BLUR_BRIGHTNESS = 0.55;
- var BLUR_SIGMA = 60;
- var debug = false;
- var promptActive = false; // default GNOME method of testing this relies on state of a transisiton
- // so we are being explicit here (do not want any races, thanks)
- function log(msg) {
- if (debug) // set 'debug' above to false to keep the noise down in journal
- console.log("BingWallpaper extension/Blur: " + msg);
- }
- // we patch UnlockDialog._updateBackgroundEffects()
- function _updateBackgroundEffects_BWP(monitorIndex) {
- // GNOME shell 3.36.4 and above
- log("_updateBackgroundEffects_BWP() called for shell >= 3.36.4");
- const themeContext = St.ThemeContext.get_for_stage(global.stage);
- for (const widget of this._backgroundGroup.get_children()) {
- // set blur effects, we have two modes in lockscreen: login prompt or clock
- // blur on when clock is visible is adjustable
- const effect = widget.get_effect('blur');
- if (promptActive) {
- log('default blur active');
- if (effect) {
- effect.set({ // GNOME defaults when login prompt is visible
- brightness: BLUR_BRIGHTNESS,
- sigma: BLUR_SIGMA * themeContext.scale_factor,
- });
- }
- }
- else {
- log('adjustable blur active');
- if (effect) {
- effect.set({ // adjustable blur when clock is visible
- brightness: BWP_BLUR_BRIGHTNESS * 0.01, // we use 0-100 rather than 0-1, so divide by 100
- sigma: BWP_BLUR_SIGMA * themeContext.scale_factor,
- });
- }
- }
- }
- }
- // we patch both UnlockDialog._showClock() and UnlockDialog._showPrompt() to let us
- // adjustable blur in a Windows-like way (this ensures login prompt is readable)
- function _showClock_BWP() {
- promptActive = false;
- this._showClock_GNOME(); // pass to default GNOME function
- this._updateBackgroundEffects();
- }
- function _showPrompt_BWP() {
- promptActive = true;
- this._showPrompt_GNOME(); // pass to default GNOME function
- this._updateBackgroundEffects();
- }
- export default class Blur {
- constructor() {
- this.enabled = false;
- log('Bing Wallpaper adjustable blur is '+supportedVersion()?'available':'not available');
- }
- set_blur_strength(value) {
- BWP_BLUR_SIGMA = this._clampValue(value);
- log("lockscreen blur strength set to "+BWP_BLUR_SIGMA);
- }
- set_blur_brightness(value) {
- BWP_BLUR_BRIGHTNESS = this._clampValue(value);
- log("lockscreen brightness set to " + BWP_BLUR_BRIGHTNESS);
- }
- // valid values are 0 to 100
- _clampValue(value) {
- if (value > 100)
- value = 100;
- if (value < 0 )
- value = 0;
- return value;
- }
- _switch(enabled) {
- if (enabled && !this.enabled) {
- this._enable();
- }
- else {
- this._disable();
- }
- }
- _enable() {
- if (supportedVersion()) {
- log("Blur._enable() called on GNOME "+Config.PACKAGE_VERSION);
- UnlockDialog.UnlockDialog.prototype._updateBackgroundEffects = _updateBackgroundEffects_BWP;
- // we override _showClock and _showPrompt to patch in updates to blur effect before calling the GNOME functions
- UnlockDialog.UnlockDialog.prototype._showClock = _showClock_BWP;
- UnlockDialog.UnlockDialog.prototype._showPrompt = _showPrompt_BWP;
- // this are the original functions which we call into from our versions above
- UnlockDialog.UnlockDialog.prototype._showClock_GNOME = _showClock;
- UnlockDialog.UnlockDialog.prototype._showPrompt_GNOME = _showPrompt;
-
- }
- this.enabled = true;
- }
- _disable() {
- if (!this.enabled)
- return;
- log("_lockscreen_blur_disable() called");
- if (supportedVersion()) {
- // restore default functions
- UnlockDialog.UnlockDialog.prototype._updateBackgroundEffects = _updateBackgroundEffects;
- UnlockDialog.UnlockDialog.prototype._showClock = _showClock;
- UnlockDialog.UnlockDialog.prototype._showPrompt = _showPrompt;
- // clean up unused functions we created
- UnlockDialog.UnlockDialog.prototype._showClock_GNOME = null;
- delete UnlockDialog.UnlockDialog.prototype._showClock_GNOME;
- UnlockDialog.UnlockDialog.prototype._showPrompt_GNOME = null;
- delete UnlockDialog.UnlockDialog.prototype._showPrompt_GNOME;
- }
- this.enabled = false;
- }
- };
- function supportedVersion() { // when current lockscren blur implementation was first shipped (we ignore earlier weird version)
- if (shellVersionMajor >= 40 ||
- (shellVersionMajor == 3 && shellVersionMinor == 36 && shellVersionPoint >= 4)) {
- return true;
- }
- return false;
- }
|