Skip to content

Commit

Permalink
Merge pull request #179 from ff2400t/develop
Browse files Browse the repository at this point in the history
Porting to GNOME 45
  • Loading branch information
GrylledCheez authored Feb 4, 2024
2 parents 0eba124 + 2f5c10a commit 1e5d0f1
Show file tree
Hide file tree
Showing 4 changed files with 160 additions and 108 deletions.
94 changes: 60 additions & 34 deletions extension.js
Original file line number Diff line number Diff line change
@@ -1,27 +1,28 @@
/* global global */

/* BEGIN NON-G45 */
const Meta = imports.gi.Meta;
const Main = imports.ui.main;
const Gio = imports.gi.Gio;
const GLib = imports.gi.GLib;
const ExtensionUtils = imports.misc.extensionUtils;
const Clutter = imports.gi.Clutter;
const St = imports.gi.St;
const Config = imports.misc.config;
const SHELL_VERSION = parseFloat(Config.PACKAGE_VERSION);
// const Meta = imports.gi.Meta;
// const Main = imports.ui.main;
// const Gio = imports.gi.Gio;
// const GLib = imports.gi.GLib;
// const ExtensionUtils = imports.misc.extensionUtils;
// const Clutter = imports.gi.Clutter;
// const St = imports.gi.St;
// const Config = imports.misc.config;
// const SHELL_VERSION = parseFloat(Config.PACKAGE_VERSION);
/* END NON-G45 */

/* BEGIN G45 */
// import Meta from 'gi://Meta';
// import * as Main from 'resource:///org/gnome/shell/ui/main.js';
// import Gio from 'gi://Gio';
// import GLib from 'gi://GLib';
// import Extension from 'resource:///org/gnome/shell/extensions/extension.js';
// import Clutter from 'gi://Clutter';
// import St from 'gi://St';
// import Config from imports.misc.config;
// const SHELL_VERSION = parseFloat(Config.PACKAGE_VERSION);
import Meta from 'gi://Meta';
import * as Main from 'resource:///org/gnome/shell/ui/main.js';
import Gio from 'gi://Gio';
import GLib from 'gi://GLib';
import {Extension} from 'resource:///org/gnome/shell/extensions/extension.js';
import Clutter from 'gi://Clutter';
import St from 'gi://St';
import {PACKAGE_VERSION} from 'resource:///org/gnome/shell/misc/config.js';
import KeyBindingsManager from './keybindings.js';
const SHELL_VERSION = parseFloat(PACKAGE_VERSION);
/* END G45 */

let onWindowGrabBegin, onWindowGrabEnd;
Expand Down Expand Up @@ -82,13 +83,16 @@ function updateSettings() {
_log(JSON.stringify(config));
}

const wintile = {
extdatadir: imports.misc.extensionUtils.getCurrentExtension().path,
shell_version: parseInt(Config.PACKAGE_VERSION.split('.')[1], 10),
};
imports.searchPath.unshift(wintile.extdatadir);
/* BEGIN NON-G45 */
// const wintile = {
// extdatadir: imports.misc.extensionUtils.getCurrentExtension().path,
// shell_version: parseInt(Config.PACKAGE_VERSION.split('.')[1], 10),
// };
// imports.searchPath.unshift(wintile.extdatadir);

// const KeyBindings = imports.keybindings;
/* END NON-G45 */

const KeyBindings = imports.keybindings;
let keyManager = null;
var oldbindings = {
unmaximize: [],
Expand Down Expand Up @@ -1068,10 +1072,24 @@ function getMonitorInfo(monitorIndex) {
/**
*
*/
class WintileExtension {

/* BEGIN NON-G45 */
// class WintileExtension {
/* END NON-G45 */

/* BEGIN G45 */
export default class WintileExtension extends Extension {
/* END G45 */
enable() {
_log('enable) Keymanager is being defined');
keyManager = new KeyBindings.Manager();

/* BEGIN G45 */
keyManager = new KeyBindingsManager();
/* END G45 */

/* BEGIN NON-G45 */
// keyManager = new KeyBindings.Manager();
/* END NON-G45 */
let desktopSettings = new Gio.Settings({schema_id: 'org.gnome.desktop.wm.keybindings'});
let mutterKeybindingSettings = new Gio.Settings({schema_id: 'org.gnome.mutter.keybindings'});
let mutterSettings = new Gio.Settings({schema_id: 'org.gnome.mutter'});
Expand Down Expand Up @@ -1139,7 +1157,13 @@ class WintileExtension {
});
Main.uiGroup.add_actor(preview);

gsettings = ExtensionUtils.getSettings();
/* BEGIN G45 */
gsettings = this.getSettings();
/* END G45 */

/* BEGIN NON-G45 */
// gsettings = ExtensionUtils.getSettings();
/* END NON-G45 */
updateSettings();

// Watch the gsettings for changes
Expand Down Expand Up @@ -1187,10 +1211,12 @@ class WintileExtension {
}
}

/**
*
* @param {object} _meta = standard meta object
*/
function init(_meta) {
return new WintileExtension();
}
/* BEGIN NON-G45 */
// /**
// *
// * @param {object} _meta = standard meta object
// */
// function init(_meta) {
// return new WintileExtension();
// }
/* END NON-G45 */
23 changes: 18 additions & 5 deletions keybindings.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,17 @@
'use strict';
/* global global */

const Main = imports.ui.main;
const Meta = imports.gi.Meta;
const Shell = imports.gi.Shell;
/* BEGIN NON-G45 */
// const Main = imports.ui.main;
// const Meta = imports.gi.Meta;
// const Shell = imports.gi.Shell;
/* END NON-G45 */

/* BEGIN G45 */
import * as Main from 'resource:///org/gnome/shell/ui/main.js';
import Meta from 'gi://Meta';
import Shell from 'gi://Shell';
/* END G45 */

/**
* Keybindings.Manager is a simple convenience class for managing keyboard
Expand All @@ -20,7 +28,12 @@ const Shell = imports.gi.Shell;
* https://developer.gnome.org/meta/stable/meta-MetaKeybinding.html
* https://gitlab.gnome.org/GNOME/gnome-shell/blob/master/js/ui/windowManager.js#L1093-1112
*/
var Manager = class Manager {
/* BEGIN NON-G45 */
// var Manager = class Manager {
/* END NON-G45 */
/* BEGIN G45 */
export default class KeyBindingsManager {
/* END G45 */
constructor() {
this._keybindings = new Map();

Expand Down Expand Up @@ -94,5 +107,5 @@ var Manager = class Manager {
global.display.disconnect(this._acceleratorActivatedId);
this.removeAll();
}
};
}

6 changes: 2 additions & 4 deletions metadata.json
Original file line number Diff line number Diff line change
@@ -1,13 +1,11 @@
{
"name": "WinTile",
"description": "WinTile is a hotkey driven window tiling system for GNOME that imitates the standard Win-Arrow keys of Windows 10, allowing you to maximize, maximize to sides, or 1/4 sized to corner across a single or multiple monitors using just Super+Arrow.\n\nAs of v16, WinTile also supports:\n- 1-5 columns and 1-5 rows for standard or ultrawide monitors\n- Top/bottom half support\n- Mouse preview and snapping for placing windows\n- 'Maximize' mode, which adds/removes GNOME animations\n- 'Ultrawide-only' mode, to allow standard screens to have different cols/row than ultrawides\n- Portrait screens will automatically swap columns and rows\n- Add gaps around tiles to avoid the 'crowded elevator' feeling'\n- Ctrl+Super+Arrow to grow a tile in that direction if space is available\n- Ctrl+drag to drop a tile in a specific spot\n- Ctrl+Super+drag to draw a grid for the new tile",
"description": "WinTile is a hotkey driven window tiling system for GNOME that imitates the standard Win-Arrow keys of Windows 10, allowing you to maximize, maximize to sides, or 1/4 sized to corner across a single or multiple monitors using just Super+Arrow.\n\nAs of v17, WinTile also supports:\n- 1-5 columns and 1-5 rows for standard or ultrawide monitors\n- Top/bottom half support\n- Mouse preview and snapping for placing windows\n- 'Maximize' mode, which adds/removes GNOME animations\n- 'Ultrawide-only' mode, to allow standard screens to have different cols/row than ultrawides\n- Portrait screens will automatically swap columns and rows\n- Add gaps around tiles to avoid the 'crowded elevator' feeling'\n- Ctrl+Super+Arrow to grow a tile in that direction if space is available\n- Ctrl+drag to drop a tile in a specific spot\n- Ctrl+Super+drag to draw a grid for the new tile",
"uuid": "[email protected]",
"url": "https://github.com/fmstrat/wintile",
"settings-schema":"org.gnome.shell.extensions.wintile",
"shell-version": [
"42",
"43",
"44"
"45"
],
"version": 17
}
145 changes: 80 additions & 65 deletions prefs.js
Original file line number Diff line number Diff line change
@@ -1,81 +1,96 @@
'use strict';

const Gio = imports.gi.Gio;
const Gtk = imports.gi.Gtk;
/* BEGIN NON-G45 */
// const Gio = imports.gi.Gio;
// const Gtk = imports.gi.Gtk;

const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension();
// const ExtensionUtils = imports.misc.extensionUtils;
// const Me = ExtensionUtils.getCurrentExtension();

const Gettext = imports.gettext;
const _ = Gettext.domain('wintile').gettext;
// const Gettext = imports.gettext;
// const _ = Gettext.domain('wintile').gettext;

const gsettings = ExtensionUtils.getSettings();
// const gsettings = ExtensionUtils.getSettings();

/**
*
*/
function init() {
// empty
}
// /**
// *
// */
// function init() {
// // empty
// }
/* END NON-G45 */

/* BEGIN G45 */
import Gio from 'gi://Gio';
import Gtk from 'gi://Gtk';
import {ExtensionPreferences} from 'resource:///org/gnome/Shell/Extensions/js/extensions/prefs.js';

/**
*
* @param {object} window - Don't worry about this. Gnome handles it for you.
*/
function fillPreferencesWindow(window) {
let builder = Gtk.Builder.new();
builder.add_from_file(`${Me.path}/settings.ui`);
let gridPage = builder.get_object('gridPage');
let behaviorPage = builder.get_object('behaviorPage');
window.add(gridPage);
window.add(behaviorPage);
export default class WinTileExtensionPreferences extends ExtensionPreferences {
/* END G45 */
/**
*
* @param {object} window - Don't worry about this. Gnome handles it for you.
*/
/* BEGIN G45 */
fillPreferencesWindow(window) {
/* END G45 */
/* BEGIN NON-G45 */
// function fillPreferencesWindow(window) {
/* END NON-G45 */
let builder = Gtk.Builder.new();
builder.add_from_file(`${this.path}/settings.ui`);
let gridPage = builder.get_object('gridPage');
let behaviorPage = builder.get_object('behaviorPage');
window.add(gridPage);
window.add(behaviorPage);

// let gsettings;
// gsettings = ExtensionUtils.getSettings();
const bindSettings = (key, input) => {
key.value = gsettings.get_value(input).deep_unpack();
gsettings.bind(input, key, 'active', Gio.SettingsBindFlags.DEFAULT);
};
/* BEGIN G45 */
let gsettings = this.getSettings();
/* END G45 */
const bindSettings = (key, input) => {
key.value = gsettings.get_value(input).deep_unpack();
gsettings.bind(input, key, 'active', Gio.SettingsBindFlags.DEFAULT);
};

const connectAndSetInt = (key, input) => {
key.value = gsettings.get_value(input).deep_unpack();
key.connect('value-changed', entry => {
gsettings.set_int(input, entry.value);
});
};
const connectAndSetInt = (key, input) => {
key.value = gsettings.get_value(input).deep_unpack();
key.connect('value-changed', entry => {
gsettings.set_int(input, entry.value);
});
};

let ultrawideOnlyInput = builder.get_object('ultrawideOnlyInput');
let nonUltrawideGroup = builder.get_object('nonUltrawideGroup');
let ultrawideOnlyInput = builder.get_object('ultrawideOnlyInput');
let nonUltrawideGroup = builder.get_object('nonUltrawideGroup');

const toggleUltrawide = () => {
if (ultrawideOnlyInput.active) {
// Show rows and columns options
nonUltrawideGroup.show();
} else {
// Hide rows and columns options
nonUltrawideGroup.hide();
}
};
const toggleUltrawide = () => {
if (ultrawideOnlyInput.active) {
// Show rows and columns options
nonUltrawideGroup.show();
} else {
// Hide rows and columns options
nonUltrawideGroup.hide();
}
};

// settings that aren't toggles need a connect
connectAndSetInt(builder.get_object('colsSettingInt'), 'cols');
connectAndSetInt(builder.get_object('rowsSettingInt'), 'rows');
connectAndSetInt(builder.get_object('nonUltraColsSettingInt'), 'non-ultra-cols');
connectAndSetInt(builder.get_object('nonUltraRowsSettingInt'), 'non-ultra-rows');
connectAndSetInt(builder.get_object('previewDistanceSettingInt'), 'distance');
connectAndSetInt(builder.get_object('previewDelaySettingInt'), 'delay');
connectAndSetInt(builder.get_object('gapSettingInt'), 'gap');
// settings that aren't toggles need a connect
connectAndSetInt(builder.get_object('colsSettingInt'), 'cols');
connectAndSetInt(builder.get_object('rowsSettingInt'), 'rows');
connectAndSetInt(builder.get_object('nonUltraColsSettingInt'), 'non-ultra-cols');
connectAndSetInt(builder.get_object('nonUltraRowsSettingInt'), 'non-ultra-rows');
connectAndSetInt(builder.get_object('previewDistanceSettingInt'), 'distance');
connectAndSetInt(builder.get_object('previewDelaySettingInt'), 'delay');
connectAndSetInt(builder.get_object('gapSettingInt'), 'gap');

// all other settings need a bind
bindSettings(builder.get_object('ultrawideOnlyInput'), 'ultrawide-only');
bindSettings(builder.get_object('maximizeInput'), 'use-maximize');
bindSettings(builder.get_object('minimizeInput'), 'use-minimize');
bindSettings(builder.get_object('previewInput'), 'preview');
bindSettings(builder.get_object('doubleWidthInput'), 'double-width');
bindSettings(builder.get_object('debugInput'), 'debug');
ultrawideOnlyInput.connect('notify::active', toggleUltrawide);
// all other settings need a bind
bindSettings(builder.get_object('ultrawideOnlyInput'), 'ultrawide-only');
bindSettings(builder.get_object('maximizeInput'), 'use-maximize');
bindSettings(builder.get_object('minimizeInput'), 'use-minimize');
bindSettings(builder.get_object('previewInput'), 'preview');
bindSettings(builder.get_object('doubleWidthInput'), 'double-width');
bindSettings(builder.get_object('debugInput'), 'debug');
ultrawideOnlyInput.connect('notify::active', toggleUltrawide);

// make sure that the non-ultrawide menu is hidden unless it's enabled
toggleUltrawide();
// make sure that the non-ultrawide menu is hidden unless it's enabled
toggleUltrawide();
}
}

0 comments on commit 1e5d0f1

Please sign in to comment.