diff --git a/extension.js b/extension.js index 93f87e0..39555bb 100644 --- a/extension.js +++ b/extension.js @@ -8,21 +8,24 @@ const ExtensionUtils = imports.misc.extensionUtils; const Me = ExtensionUtils.getCurrentExtension(); const Utils = Me.imports.utils; -const Valet = GObject.registerClass( - class Valet extends PanelMenu.Button { +const PhpLaravelValet = GObject.registerClass( + class PhpLaravelValet extends PanelMenu.Button { _init() { super._init(0.0, null, false); + this._settings = ExtensionUtils.getSettings('org.gnome.shell.extensions.php-laravel-valet'); + this._indicatorText = new St.Label({text: 'Loading...', y_align: Clutter.ActorAlign.CENTER}); this.add_actor(this._indicatorText); - this.menu.connect('open-state-changed', (menu, open) => { - if (open) this._refreshMenu() - }); + // Initialising the menu with demo item + this.menu.addMenuItem(new PopupMenu.PopupMenuItem('Loading...')); this._refreshIndicator(); - this._refreshMenu(); + this.menu.connect('open-state-changed', (menu, open) => { + if (open) this._refreshMenu() + }); } _refreshIndicator() { @@ -76,9 +79,10 @@ const Valet = GObject.registerClass( } _switchPhp(version) { + const terminal = this._settings.get_string('default-shell').split(' '); try { let proc = Gio.Subprocess.new( - ['x-terminal-emulator', '-e', 'valet', 'use', version], + terminal.concat(['valet', 'use', version]), Gio.SubprocessFlags.STDOUT_PIPE | Gio.SubprocessFlags.STDERR_PIPE ); @@ -92,14 +96,14 @@ const Valet = GObject.registerClass( } ) -let valetIndicator = null; +let phpLaravelValet = null; function enable() { - valetIndicator = new Valet(); - Main.panel.addToStatusArea('valet', valetIndicator); + phpLaravelValet = new PhpLaravelValet(); + Main.panel.addToStatusArea('php-laravel-valet', phpLaravelValet); } function disable() { - valetIndicator.destroy(); - valetIndicator = null; + phpLaravelValet.destroy(); + phpLaravelValet = null; } diff --git a/metadata.json b/metadata.json index ecfbc45..edfb588 100644 --- a/metadata.json +++ b/metadata.json @@ -7,6 +7,6 @@ "41", "42" ], - "version": 2, + "version": 3, "url": "https://github.com/rahulhaque/php-laravel-valet-gnome-shell-extension" } diff --git a/schemas/gschemas.compiled b/schemas/gschemas.compiled new file mode 100644 index 0000000..f8fdeb9 Binary files /dev/null and b/schemas/gschemas.compiled differ diff --git a/schemas/org.gnome.shell.extensions.php-laravel-valet.gschema.xml b/schemas/org.gnome.shell.extensions.php-laravel-valet.gschema.xml new file mode 100644 index 0000000..3736dab --- /dev/null +++ b/schemas/org.gnome.shell.extensions.php-laravel-valet.gschema.xml @@ -0,0 +1,20 @@ + + + + + 'right' + Position in Panel + Position in Panel ('left', 'center', 'right') + + + 0 + Index in panel box + Index within the selected panel box (0: first, 1: second, ..., -1: last) + + + 'x-terminal-emulator -e' + Default shell to execute extension commands + Default shell to execute extension commands + + + \ No newline at end of file diff --git a/utils.js b/utils.js index 7c3bde3..2c96bad 100644 --- a/utils.js +++ b/utils.js @@ -1,7 +1,11 @@ 'use strict'; const Bytes = imports.byteArray; -const GLib = imports.gi.GLib; +const {GLib, Gio} = imports.gi; +const ExtensionUtils = imports.misc.extensionUtils; +const Me = ExtensionUtils.getCurrentExtension(); + +const _settings = ExtensionUtils.getSettings('org.gnome.shell.extensions.php-laravel-valet'); function safeSpawn(cmd) { try { @@ -11,18 +15,9 @@ function safeSpawn(cmd) { } } -function valetStatus() { - const res = safeSpawn('/bin/bash -c "valet --version && valet status"'); - if (res[3] == 0) return Bytes.toString(res[1]).split('\n').filter(item => !!item); - return false; -} - -function valetRestart() { - GLib.spawn_command_line_async('x-terminal-emulator -e valet restart'); -} - -function valetStop() { - GLib.spawn_command_line_async('x-terminal-emulator -e valet stop'); +function shellSpawn(cmd) { + const terminal = _settings.get_string('default-shell'); + GLib.spawn_command_line_async(`${terminal} ${cmd}`); } function phpVersion() { @@ -36,3 +31,17 @@ function phpList() { if (res[3] == 0) return Bytes.toString(res[1]).split('\n').filter(item => !!item).reverse(); return false; } + +function valetStatus() { + const res = safeSpawn('/bin/bash -c "valet --version && valet status"'); + if (res[3] == 0) return Bytes.toString(res[1]).split('\n').filter(item => !!item); + return false; +} + +function valetRestart() { + shellSpawn('valet restart'); +} + +function valetStop() { + shellSpawn('valet stop'); +}