From ad30494e3e91f615cdf41c120999924d45779ed0 Mon Sep 17 00:00:00 2001 From: Pavel Shabardin Date: Sat, 4 Jan 2020 18:33:43 +0400 Subject: [PATCH] [upd] #47 Separated action with custom keybinding for capture focus --- drop-down-terminal-x@bigbn.pro/extension.js | 86 ++++++++---------- .../gschemas.compiled | Bin 2620 -> 2696 bytes .../prefs.gtkbuilder | 59 +++++++++++- .../prefs.gtkbuilder~ | 53 ++++++++++- drop-down-terminal-x@bigbn.pro/prefsWindow.js | 2 + ...pro.bigbn.drop-down-terminal-x.gschema.xml | 8 ++ 6 files changed, 154 insertions(+), 54 deletions(-) diff --git a/drop-down-terminal-x@bigbn.pro/extension.js b/drop-down-terminal-x@bigbn.pro/extension.js index dece945..5e7882b 100644 --- a/drop-down-terminal-x@bigbn.pro/extension.js +++ b/drop-down-terminal-x@bigbn.pro/extension.js @@ -56,7 +56,6 @@ const ANIMATION_CONFLICT_EXTENSION_UUIDS = [ const TERMINAL_WINDOW_ACTOR_NAME = 'dropDownTerminalXWindow' const TERMINAL_WINDOW_WM_CLASS = 'DropDownTerminalXWindow' -const DEBUG = false const FIRST_START_SETTING_KEY = 'first-start' const ENABLE_ANIMATION_SETTING_KEY = 'enable-animation' @@ -79,6 +78,7 @@ const CLOSE_TAB_SHORTCUT_SETTING_KEY = 'close-tab-shortcut' const INCREASE_TEXT_SHORTCUT_SETTING_KEY = 'increase-text-shortcut' const DECREASE_TEXT_SHORTCUT_SETTING_KEY = 'decrease-text-shortcut' const FULLSCREEN_SHORTCUT_SETTING_KEY = 'toggle-fullscreen-shortcut' +const CAPTURE_FOCUS_SETTING_KEY = 'capture-focus-shortcut' const PRIMARY_MONITOR_SETTING_KEY = 'primary-monitor' @@ -134,42 +134,27 @@ const DropDownTerminalXIface = ` -// helper to only log in debug mode -function debug (text) { DEBUG && log('[DDT] ' + text) } - // window border effect class // // we should use a delegate to avoid the GType crashes (https://bugzilla.gnome.org/show_bug.cgi?id=688973) // but we can't since the Clutter.Effect is abstract, so let's add a crappy hack there -if (window.__DDTInstance === undefined) { - window.__DDTInstance = 1 -} +if (window.__DDTInstance === undefined) window.__DDTInstance = 1 const SouthBorderEffect = new Lang.Class({ Name: 'SouthBorderEffect-' + window.__DDTInstance++, Extends: Clutter.Effect, - _init: function () { + _init () { this.parent() - // ExtensionUtils.initTranslations() - this._color = new Cogl.Color() - - if (Convenience.GTK_VERSION >= 31590) { - this._color.init_from_4ub(0x1c, 0x1f, 0x1f, 0xff) - this._width = 1 - } else { - this._color.init_from_4ub(0xa5, 0xa5, 0xa5, 0xff) - this._width = 2 - } + this._color.init_from_4ub(0x1c, 0x1f, 0x1f, 0xff) + this._width = 1 }, - vfunc_paint: function () { + vfunc_paint () { const actor = this.get_actor() const geom = actor.get_allocation_geometry() - actor.continue_paint() - Cogl.set_source_color(this._color) Cogl.rectangle(0, geom.height, geom.width, geom.height - this._width) } @@ -179,7 +164,7 @@ const SouthBorderEffect = new Lang.Class({ const MissingVteDialog = new Lang.Class({ Name: 'MissingDepsDialog', - _init: function () { + _init () { this._delegate = new ModalDialog.ModalDialog({ styleClass: 'modal-dialog' }) this._delegate.setButtons([{ @@ -222,7 +207,7 @@ const MissingVteDialog = new Lang.Class({ this._delegate.contentLayout.add(box) }, - open: function () { + open () { this._delegate.open() } }) @@ -231,12 +216,12 @@ const MissingVteDialog = new Lang.Class({ const DropDownTerminalXExtension = new Lang.Class({ Name: 'DropDownTerminalXExtension', - _init: function () { + _init () { // retrieves the settings this._settings = Convenience.getSettings(Me.path, Me.metadata.id) }, - enable: function () { + enable () { // initializes the child pid and bus proxy members early as it used to know if it has been spawn already this._childPid = null @@ -257,13 +242,13 @@ const DropDownTerminalXExtension = new Lang.Class({ this._actorMappedHandlerId = global.window_manager.connect('map', Lang.bind(this, this._windowMapped)) // geometry update on monitor configuration change or panel size change - this._monitorsChangedHandlerId = Main.layoutManager.connect('monitors-changed', Lang.bind(this, function () { + this._monitorsChangedHandlerId = Main.layoutManager.connect('monitors-changed', () => { Convenience.throttle(100, this, this._updateWindowGeometry) // throttles at 10Hz (it's an "heavy weight" setting) - })) + }) - this._panelAllocationNotificationHandlerId = Main.layoutManager.panelBox.connect('notify::allocation', Lang.bind(this, function () { + this._panelAllocationNotificationHandlerId = Main.layoutManager.panelBox.connect('notify::allocation', () => { Convenience.throttle(100, this, this._updateWindowGeometry) // throttles at 10Hz (it's an "heavy weight" setting) - })) + }) this._panelScrollEventHandlerId = Main.panel.actor.connect('scroll-event', Lang.bind(this, this._panelScrolled)) const busRun = (actionName, ...args) => this._busProxy && this._busProxy[actionName](...args) @@ -276,6 +261,7 @@ const DropDownTerminalXExtension = new Lang.Class({ [CLOSE_TAB_SHORTCUT_SETTING_KEY, () => busRun('CloseTabRemote')], [INCREASE_TEXT_SHORTCUT_SETTING_KEY, () => busRun('IncreaseFontSizeRemote')], [DECREASE_TEXT_SHORTCUT_SETTING_KEY, () => busRun('DecreaseFontSizeRemote')], + [CAPTURE_FOCUS_SETTING_KEY, () => busRun('FocusRemote')], [FULLSCREEN_SHORTCUT_SETTING_KEY, () => { this.fullscreenEnabled = !this.fullscreenEnabled this._updateWindowGeometry(this.fullscreenEnabled) @@ -377,7 +363,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._handleFirstStart() }, - disable: function () { + disable () { // unbinds the shortcut this.bindings.forEach(([key]) => this._unbindShortcut(key)) @@ -450,7 +436,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._display = null }, - _toggle: function () { + _toggle () { console.log('Asked to toggle') // checks if there is not an instance of a previous child, mainly because it survived a shell restart @@ -518,7 +504,7 @@ const DropDownTerminalXExtension = new Lang.Class({ } }, - _panelScrolled: function (actor, event) { + _panelScrolled (actor, event) { // checks if toggle on scroll is enabled if (!this._toggleOnScrollEnabled) return const direction = event.get_scroll_direction() @@ -530,13 +516,13 @@ const DropDownTerminalXExtension = new Lang.Class({ this._toggle() }, - _updateAnimationProperties: function () { + _updateAnimationProperties () { this._animationEnabled = this._settings.get_boolean(ENABLE_ANIMATION_SETTING_KEY) this._openingAnimationTimeMillis = this._settings.get_uint(OPENING_ANIMATION_TIME_SETTING_KEY) this._closingAnimationTimeMillis = this._settings.get_uint(CLOSING_ANIMATION_TIME_SETTING_KEY) }, - _updateToggleOnScroll: function () { + _updateToggleOnScroll () { this._toggleOnScrollEnabled = this._settings.get_boolean(ENABLE_TOGGLE_ON_SCROLL_SETTING_KEY) }, @@ -628,19 +614,19 @@ const DropDownTerminalXExtension = new Lang.Class({ return false }, - _bindShortcut: function (key, action) { + _bindShortcut (key, action) { // introduced in 3.16 if (Main.wm.addKeybinding && Shell.ActionMode) Main.wm.addKeybinding(key, this._settings, Meta.KeyBindingFlags.NONE, Shell.ActionMode.NORMAL, action.bind(this)) // introduced in 3.7.5 else if (Main.wm.addKeybinding && Shell.KeyBindingMode) Main.wm.addKeybinding(key, this._settings, Meta.KeyBindingFlags.NONE, Shell.KeyBindingMode.NORMAL | Shell.KeyBindingMode.MESSAGE_TRAY, action.bind(this)) }, - _unbindShortcut: function (key) { + _unbindShortcut (key) { if (Main.wm.removeKeybinding) Main.wm.removeKeybinding(key) else global.display.remove_keybinding(key) }, - _windowCreated: function (display, window) { + _windowCreated (display, window) { // filter out the terminal window using its wmclass if (String(window.get_wm_class()) !== TERMINAL_WINDOW_WM_CLASS) { return @@ -651,7 +637,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._setWindowActor(window.get_compositor_private()) }, - _windowMapped: function (wm, actor) { + _windowMapped (wm, actor) { // filter out the actor using its name if (String(actor.get_name()) !== TERMINAL_WINDOW_ACTOR_NAME) { return @@ -728,7 +714,7 @@ const DropDownTerminalXExtension = new Lang.Class({ } }, - _forkChild: function () { + _forkChild () { // resets the child finishing flags this._quitingChild = false this._killingChild = false @@ -775,7 +761,7 @@ const DropDownTerminalXExtension = new Lang.Class({ GLib.child_watch_add(GLib.PRIORITY_DEFAULT, pid, Lang.bind(this, this._childExited), null) }, - _killChild: function () { + _killChild () { if (this._childPid !== null) { // we are killing the child ourself, so set the flag telling this is intended this._killingChild = true @@ -807,7 +793,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._forgetChild() }, - _busNameAppeared: function (connection, name, nameOwner) { + _busNameAppeared (connection, name, nameOwner) { // creates a dbus proxy on the interface exported by the child process const DropDownTerminalXDBusProxy = Gio.DBusProxy.makeProxyWrapper(DropDownTerminalXIface) @@ -853,13 +839,13 @@ const DropDownTerminalXExtension = new Lang.Class({ } }, - _busNameVanished: function (connection, name) { + _busNameVanished (connection, name) { // forgets the bus proxy and the child entirely since they will be automatically picked // up again once available, even if that means spawning the child again if necessary this._forgetChild() }, - _forgetChild: function () { + _forgetChild () { // destroys the dbus proxy aggressively delete this._busProxy this._busProxy = null @@ -869,7 +855,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._childPid = null }, - _setWindowActor: function (actor) { + _setWindowActor (actor) { // adds a gray border on south of the actor to mimick the shell borders actor.clear_effects() actor.add_effect(new SouthBorderEffect()) @@ -881,7 +867,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._windowActor = actor }, - _evaluateSizeSpec: function (monitor, heightSpec, vertical) { + _evaluateSizeSpec (monitor, heightSpec, vertical) { // updates the height from the height spec, so it's picked const match = heightSpec.trim().match(/^([1-9]\d*)\s*(px|%)$/i) @@ -912,7 +898,7 @@ const DropDownTerminalXExtension = new Lang.Class({ } }, - _updateClip: function () { + _updateClip () { const monitor = this._getCurrentMonitor() if (!this._windowActor || !this._windowActor.hasOwnProperty('allocation')) return const a = this._windowActor.allocation @@ -931,7 +917,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._windowActor.set_clip(clip.x1, clip.y1, clip.x2 - clip.x1, clip.y2 - clip.y1) }, - _shouldAnimateWindow: function () { + _shouldAnimateWindow () { if (!this._animationEnabled || !Main.wm._shouldAnimate()) { return false } @@ -945,7 +931,7 @@ const DropDownTerminalXExtension = new Lang.Class({ return true }, - _getCommandEnv: function () { + _getCommandEnv () { // builds the environment const env = {} @@ -965,7 +951,7 @@ const DropDownTerminalXExtension = new Lang.Class({ return envArray }, - _handleFirstStart: function () { + _handleFirstStart () { // checks the first start key if (!this._settings.get_boolean(FIRST_START_SETTING_KEY)) { return @@ -983,7 +969,7 @@ const DropDownTerminalXExtension = new Lang.Class({ this._settings.set_boolean(FIRST_START_SETTING_KEY, false) }, - _checkDependencies: function () { + _checkDependencies () { try { imports.gi.Vte } catch (e) { diff --git a/drop-down-terminal-x@bigbn.pro/gschemas.compiled b/drop-down-terminal-x@bigbn.pro/gschemas.compiled index 9c6137bbbd6e067380079437113e7d6501a92919..30c2143490549805d1e394e837ae2d6ad4fcd34c 100644 GIT binary patch literal 2696 zcmai0U2GIp7`+IsrG@feDQYc3>#kvFD?C6_5SyS?`_L$uYSb{hbGth*J2T$7(;pGy zPmO<&RN@0sWAwp@8U-GV;1eN6`qCF3lxQ$DQ7J(T#ur0k)^qO8Zo7rVNlwq{xp(h; z_q#vyJ@kaFT-(`nhziM43v#mw+iV^U)3xudyB}5U=SUn8UC&;e@ zp$ax;++4=r=%^sHoM70uv{VJxw>^tL79w?zAtCr4V*V^(Xi)>y0(A)*z>5+r1~&pr zfTh4PU^%b?XiBgeyau>^7Vd&BqZOK13*0>m>!90!Lyf0@Y6o+kOT>`40B%B1KNj|X zNuPQV{1n&%Hmsc(pikWhe+PIc(Es%0Rr=KQ2fz++a@*&_^r@G^9|4a6#~aUf(5G&K z{~`Drpf}iCPoKI0{sedu`0JB*o9R<8hCc2CpV1D@?Tx0gOO#~A?c0i5%ny+xmz{YStr0w=d#`kg-YGWbWqp8^Zp zp4>^FnsJ^2p9RhwIM~2FL|p@a0(=GNes7=Cj{ellkGK`>z`VZ?XXsPk2EP^D27KIq zLeZyQ34aH;7dUpL`4D|-#<>SP1U&OW?FIVOtKg4=j{>77Pkl$9n(sXZ{sK67f8SyH z)Z7nez~_Md(?7gSpLzxSDe!N=9nJTyqEF3n{vl&CZ}|7xee|j6x6%VTe?5MdJ~i{) z3+@NTe(q|gPtAPh!3E%zO)vD&r{;bb0UrReExUf9PtE@0;O~Lceb?WhPtEwJ!B>H$ zyRS{tr(OfUZXxmnJknI#PoJ9cq`*DE`{y@prB7}416TpMZCA{>pys-agO38@&)1$} ze`>DF3Gi3Ir9akxM4y`HVgft~EZOqXeEQUke+qmJDBm^Iylcq3Zz}gnHdaxf*eH6u zAiEDN&40L~N=A`)Sn=T=X%|G1cTRD)??~mjz7)k;k&05IcAQQZ0Pj=}psONnMcP(;<2;edq_v%itT2dN zU5T4_sz}A@tOwiAS+W^I z#hB%BwX*#vw3YO;qn0O!q{kQHPT?QK<;xLmA?`WT7G}DSxw*W?)@BkbiyXPnBeu<* zogqFW$lk`#)_Ku^4^D^q;B?&VgVP~I6lGQ5c^0M~#5zpY2}5Mk(zi37v~-ZmfzYAU zl_8q;%DXi_Wufgjm~^R8bR|(RzZl_$iBzxO2+n)eWIQ>jt41u3mxNSVF0;O2X)lzQ zi6K~BCJE*4vEy=LW|kshcBoZMm*uorLS&)LpE9P{!fT#y1OKEmaFN1M7hnpcUXc@akn<#rli&7}uZ; mV9mu6khK`=Eqv-sO$EZdg}4)7EykLSbsB3h)^e=1`1}XlvQr2E literal 2620 zcmai0TWl0n7(NwRg#s;?mKFg)F4;9qFMtUorD_dYwGWMgsYXm^cTRT)X6KA&W=bnc z>V+5;9yB}Wn zyMREewwznY`E8C?f#sQNgWjlT9X80}Gs?LssX4wEJO~ta{C<)? z^>X+l;4z?K+Y58(Q*%AXz~ey8KSy%(sX2ZEd=@x(Pu~&x)D7^@gMS3XU#~n#pL!Ym zOW-TOr>$>Xq))vBej|e41WY`Cu%6$Sx)%N#@cqE(snefxJT=!p0Nw*U-TuX1`qbR- z2zU%=+&wc*pLzxS=~Hu_3GkP|2mPOD`qW(KPvB`_&%1T!=~Fks7q=ou zfL^tCK7HzX_$}a7z)M@6>!D9gKLfUaGkup|rBBWH+zZ|bbo~19XY{GL{y}gN@L!vn zpij;CjDZgU{ZD=MCw*$>!!hvt!1$Z3hv`#u{AuvlK;^tp^Spcm9z>EKUUcSrj;H2& z0`N)T;pV!2`qW&{B={E~zk1it^r@K-m%!cgg!uczw_52_FNEI@9ss)D-sjM#W}J)Q z67XH=fXO%N1@Onfhk&W0k8I_5YQFb4cpPxfop_x-HTN|Eo&+xZvHm^!)aG1(r+`!2 zFZ@QIn(Lea*Wf_U+wjCr`qW%!BX|XHVEWq^=~FL--vMTA3G-TcUe4Cmup7ELPhw1R zWpdek97d{SVU+%XeJ9pFZj}_gas5?S*IJ#Q%aw_5)1KV+2 zzaTmT6hW*Z&~o?&(+Tt1J~!cU5&n^d0W=#)n2D4}KVh^na*jpC^ z?5pg%>jCy-_Gk809Cc9*O+MBkQnSZX`F-${EWmGv#3*yE<%fEtT@q#f9w_hj9jQIn zm!ga)gqcx0&SqWzW+!%bJmfR6?WO0nx`IH3ZZ$u5so?4w_zzxb)?m(Dx`s#jIYpT< zEccl63nj|P$81W8BGfOb!^$Z!gTpL8@c*5Y>Oszr zTAm!19-l?O)2tr PwQ|zqE6us!J8}I7g-<@x diff --git a/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder b/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder index 2bc22b1..cce501c 100644 --- a/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder +++ b/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder @@ -2,6 +2,14 @@ + + + + + + + + @@ -1079,13 +1087,15 @@ True False + 12 + 6 True True True False - Toggle + Toggle maximize 0.89999997615814209 @@ -1125,6 +1135,51 @@ 0 + + + True + False + Capture focus + 0.89999997615814209 + + + 0 + 1 + + + + + True + False + + + + 2 + 1 + + + + + True + False + + + True + True + capture-focus-liststore + False + 0 + + + + + + + + 1 + 1 + + @@ -1135,7 +1190,7 @@ False 6 6 - Maximize + Miscellaneous diff --git a/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder~ b/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder~ index f11a330..c5cc084 100644 --- a/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder~ +++ b/drop-down-terminal-x@bigbn.pro/prefs.gtkbuilder~ @@ -2,6 +2,14 @@ + + + + + + + + @@ -1079,13 +1087,15 @@ True False + 12 + 6 True True True False - Toggle + Toggle maximize 0.89999997615814209 @@ -1125,6 +1135,45 @@ 0 + + + True + False + Capture focus + 0.89999997615814209 + + + 0 + 1 + + + + + True + False + + + + 2 + 1 + + + + + True + True + capture-focus-liststore + False + 0 + + + + + + 1 + 1 + + @@ -1135,7 +1184,7 @@ False 6 6 - Fullscreen + Miscellaneous diff --git a/drop-down-terminal-x@bigbn.pro/prefsWindow.js b/drop-down-terminal-x@bigbn.pro/prefsWindow.js index 9b0b008..93ffb94 100644 --- a/drop-down-terminal-x@bigbn.pro/prefsWindow.js +++ b/drop-down-terminal-x@bigbn.pro/prefsWindow.js @@ -62,6 +62,7 @@ const INCREASE_TEXT_SHORTCUT_SETTING_KEY = 'increase-text-shortcut' const DECREASE_TEXT_SHORTCUT_SETTING_KEY = 'decrease-text-shortcut' const FULLSCREEN_SHORTCUT_SETTING_KEY = 'toggle-fullscreen-shortcut' +const CAPTURE_FOCUS_SETTING_KEY = 'capture-focus-shortcut' const PRIMARY_MONITOR_SETTING_KEY = 'primary-monitor' const MULTI_MONITOR_MODE_SETTING_KEY = 'multi-monitor-mode' @@ -145,6 +146,7 @@ var DropDownTerminalSettingsWidget = new GObject.Class({ this._makeShortcutEdit('increase-text-shortcut-treeview', 'increase-text-shortcut-liststore', INCREASE_TEXT_SHORTCUT_SETTING_KEY) this._makeShortcutEdit('decrease-text-shortcut-treeview', 'decrease-text-shortcut-liststore', DECREASE_TEXT_SHORTCUT_SETTING_KEY) this._makeShortcutEdit('fullscreen-shortcut-treeview', 'fullscreen-shortcut-liststore', FULLSCREEN_SHORTCUT_SETTING_KEY) + this._makeShortcutEdit('capture-focus-tree-view', 'capture-focus-liststore', CAPTURE_FOCUS_SETTING_KEY) this._initMonitorWidgets() this._initTabsPositionWidgets() diff --git a/drop-down-terminal-x@bigbn.pro/pro.bigbn.drop-down-terminal-x.gschema.xml b/drop-down-terminal-x@bigbn.pro/pro.bigbn.drop-down-terminal-x.gschema.xml index 43daa79..57ff0a3 100644 --- a/drop-down-terminal-x@bigbn.pro/pro.bigbn.drop-down-terminal-x.gschema.xml +++ b/drop-down-terminal-x@bigbn.pro/pro.bigbn.drop-down-terminal-x.gschema.xml @@ -307,5 +307,13 @@ + + grave']]]> + Shortcut used to toggle focus + + Shortcut used to toggle focus + + +