From 18e5f4594cc63b4cf63957e999dcf078fea56fa0 Mon Sep 17 00:00:00 2001 From: Dome Date: Mon, 11 Aug 2025 01:51:54 +0200 Subject: [PATCH] Create prefs.interim.js --- prefs.interim.js | 89 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) create mode 100644 prefs.interim.js diff --git a/prefs.interim.js b/prefs.interim.js new file mode 100644 index 0000000..2d5fead --- /dev/null +++ b/prefs.interim.js @@ -0,0 +1,89 @@ +/////////////////////////////////////////////////////////////// +// Simple-Tiling – MODERN MENU (GNOME Shell 40-44) // +// © 2025 domoel – MIT // +/////////////////////////////////////////////////////////////// + +'use strict'; + +import { ExtensionPreferences } from 'resource:///org/gnome/shell/extensions/js/extensions/prefs.js'; +import Adw from 'gi://Adw'; +import Gio from 'gi://Gio'; +import Gtk from 'gi://Gtk'; +import GLib from 'gi://GLib'; + +export default class SimpleTilingPrefs extends ExtensionPreferences { + fillPreferencesWindow(window) { + const settings = this.getSettings(); + const page = new Adw.PreferencesPage(); + window.add(page); + + // --- Group for Window Gaps --- + const groupGaps = new Adw.PreferencesGroup({ title: 'Window Gaps' }); + page.add(groupGaps); + + const rowInnerGap = new Adw.SpinRow({ + title: 'Inner Gap', + subtitle: 'The gap between windows in pixels.', + adjustment: new Gtk.Adjustment({ lower: 0, upper: 100, step_increment: 1 }), + }); + groupGaps.add(rowInnerGap); + settings.bind('inner-gap', rowInnerGap, 'value', Gio.SettingsBindFlags.DEFAULT); + + const rowOuterH = new Adw.SpinRow({ + title: 'Outer Gap (horizontal)', + subtitle: 'Left / right screen edges (pixels)', + adjustment: new Gtk.Adjustment({ lower: 0, upper: 100, step_increment: 1 }), + }); + groupGaps.add(rowOuterH); + settings.bind('outer-gap-horizontal', rowOuterH, 'value', Gio.SettingsBindFlags.DEFAULT); + + const rowOuterV = new Adw.SpinRow({ + title: 'Outer Gap (vertical)', + subtitle: 'Top / bottom screen edges (pixels)', + adjustment: new Gtk.Adjustment({ lower: 0, upper: 100, step_increment: 1 }), + }); + groupGaps.add(rowOuterV); + settings.bind('outer-gap-vertical', rowOuterV, 'value', Gio.SettingsBindFlags.DEFAULT); + + // --- Group for Window Behavior --- + const groupBehavior = new Adw.PreferencesGroup({ title: 'Window Behavior' }); + page.add(groupBehavior); + + const rowNewWindow = new Adw.ComboRow({ + title: 'Open new windows as', + subtitle: 'Whether a new window starts as Master or Stack', + model: new Gtk.StringList({ + strings: ['Stack Window (Default)', 'Master Window'], + }), + }); + groupBehavior.add(rowNewWindow); + + const currentBehavior = settings.get_string('new-window-behavior'); + rowNewWindow.selected = currentBehavior === 'master' ? 1 : 0; + + rowNewWindow.connect('notify::selected', () => { + const newVal = rowNewWindow.selected === 1 ? 'master' : 'stack'; + settings.set_string('new-window-behavior', newVal); + }); + + // --- Group for Keybindings --- + const groupKeys = new Adw.PreferencesGroup({ title: 'Keybindings' }); + page.add(groupKeys); + + const rowKeys = new Adw.ActionRow({ + title: 'Configure Shortcuts', + subtitle: 'Adjust all shortcuts in GNOME Keyboard settings.', + }); + groupKeys.add(rowKeys); + + const btnOpenKeyboard = new Gtk.Button({ label: 'Open Keyboard Settings' }); + btnOpenKeyboard.connect('clicked', () => { + const appInfo = Gio.AppInfo.create_from_commandline( + 'gnome-control-center keyboard', null, Gio.AppInfoCreateFlags.NONE + ); + appInfo.launch([], null); + }); + rowKeys.add_suffix(btnOpenKeyboard); + rowKeys.set_activatable_widget(btnOpenKeyboard); + } +}