From 158cc37a0d09ec0e0ef9e5555179f84b98b0886f Mon Sep 17 00:00:00 2001 From: Gerome Matilla <40349590+manilarome@users.noreply.github.com> Date: Wed, 1 Apr 2020 17:13:58 +0800 Subject: [PATCH] Apply placement margins on awful.tooltip (#3053) Co-authored-by: Gerome Matilla --- lib/awful/tooltip.lua | 56 ++++++++++++++++++++------- tests/examples/awful/tooltip/gaps.lua | 30 ++++++++++++++ 2 files changed, 71 insertions(+), 15 deletions(-) create mode 100644 tests/examples/awful/tooltip/gaps.lua diff --git a/lib/awful/tooltip.lua b/lib/awful/tooltip.lua index b75a758b..6dd7ed2e 100644 --- a/lib/awful/tooltip.lua +++ b/lib/awful/tooltip.lua @@ -108,9 +108,13 @@ local offset = { -- @beautiful beautiful.tooltip_opacity -- @param number opacity Between 0 and 1 +--- The tooltip margins. +-- @beautiful beautiful.tooltip_gaps +-- @param table + --- The default tooltip shape. -- The default shape for all tooltips is a rectangle. However, by setting --- this variable they can default to rounded rectangle or stretched octogons. +-- this variable they can default to rounded rectangle or stretched octagons. -- @beautiful beautiful.tooltip_shape -- @tparam[opt=gears.shape.rectangle] gears.shape shape A `gears.shape` -- compatible function @@ -136,6 +140,7 @@ local function apply_outside_mode(self) preferred_positions = self.preferred_positions, preferred_anchors = self.preferred_alignments, honor_workarea = true, + margins = self._private.gaps }) self.current_position = position @@ -468,12 +473,12 @@ function tooltip:set_timeout(timeout) self:emit_signal("property::timeout", timeout) end ---- Set all margins around the tooltip textbox +--- Set all margins around the tooltip textbox. -- -- @DOC_awful_tooltip_margins_EXAMPLE@ -- -- @property margins --- @tparam number|table New margins value +-- @tparam number|table New margins value. -- @propemits true false function tooltip:set_margins(val) @@ -508,12 +513,12 @@ function tooltip:set_border_color(val) self:emit_signal("property::border_color", val) end ---- Set the margins around the left and right of the tooltip textbox +--- Set the margins around the left and right of the tooltip textbox. -- -- @DOC_awful_tooltip_margins_leftright_EXAMPLE@ -- -- @property margins_leftright --- @tparam number New margins value +-- @tparam number New margins value. -- @propemits true false function tooltip:set_margin_leftright(val) @@ -527,12 +532,12 @@ function tooltip:set_margins_leftright(val) self:set_margin_leftright(val) end ---- Set the margins around the top and bottom of the tooltip textbox +--- Set the margins around the top and bottom of the tooltip textbox. -- -- @DOC_awful_tooltip_margins_topbottom_EXAMPLE@ -- -- @property margins_topbottom --- @tparam number New margins value +-- @tparam number New margins value. -- @propemits true false function tooltip:set_margin_topbottom(val) @@ -546,6 +551,22 @@ function tooltip:set_margins_topbottom(val) self:set_margin_topbottom(val) end +--- Set the margins between the tooltip and its parent. +-- +-- @DOC_awful_tooltip_gaps_EXAMPLE@ +-- +-- @property gaps +-- @tparam number|table New margins value. +-- @propemits true false + +function tooltip:set_gaps(val) + self._private.gaps = val +end + +function tooltip:get_gaps() + return self._private.gaps +end + --- Add tooltip to an object. -- -- @tparam tooltip self The tooltip. @@ -594,14 +615,15 @@ end -- seconds. -- @tparam[opt=apply_dpi(5)] integer args.margin_leftright The left/right margin for the text. -- @tparam[opt=apply_dpi(3)] integer args.margin_topbottom The top/bottom margin for the text. --- @tparam[opt=nil] gears.shape args.shape The shape --- @tparam[opt] string args.bg The background color --- @tparam[opt] string args.fg The foreground color --- @tparam[opt] string args.border_color The tooltip border color --- @tparam[opt] number args.border_width The tooltip border width --- @tparam[opt] string args.align The horizontal alignment --- @tparam[opt] string args.font The tooltip font --- @tparam[opt] number args.opacity The tooltip opacity +-- @tparam[opt=nil] gears.shape args.shape The shape. +-- @tparam[opt] string args.bg The background color. +-- @tparam[opt] string args.fg The foreground color. +-- @tparam[opt] string args.border_color The tooltip border color. +-- @tparam[opt] number args.border_width The tooltip border width. +-- @tparam[opt] string args.align The horizontal alignment. +-- @tparam[opt] string args.font The tooltip font. +-- @tparam[opt] number args.opacity The tooltip opacity. +-- @tparam[opt] table|number args.gaps The tooltip margins. -- @treturn awful.tooltip The created tooltip. -- @see add_to_object -- @see timeout @@ -621,6 +643,10 @@ function tooltip.new(args) self._private.align = args.align or beautiful.tooltip_align or "right" self._private.shape = args.shape or beautiful.tooltip_shape or shape.rectangle + self._private.gaps = args.gaps or beautiful.tooltip_gaps or { + left = args.gaps or 0, right = args.gaps or 0, + top = args.gaps or 0, bottom = args.gaps or 0 + } -- private data if args.delay_show then diff --git a/tests/examples/awful/tooltip/gaps.lua b/tests/examples/awful/tooltip/gaps.lua new file mode 100644 index 00000000..c21de60d --- /dev/null +++ b/tests/examples/awful/tooltip/gaps.lua @@ -0,0 +1,30 @@ +--DOC_GEN_IMAGE +--DOC_NO_USAGE +--DOC_HIDE_ALL +screen[1]._resize {width = 300, height = 150} +screen.no_outline = true +local awful = {tooltip = require("awful.tooltip")} +local beautiful = require("beautiful") +local wibox = require("wibox") + +-- mouse.coords{x=50, y= 10} + + local wb = wibox {width = 100, height = 44, x = 100, y = 50, visible = true} + +require("gears.timer").run_delayed_calls_now() + +for _, side in ipairs{ "left", "right", "bottom", "top" } do + local tt = awful.tooltip { + text = side, + objects = {wb}, + mode = "outside", + preferred_positions = {side}, + preferred_alignments = {"back"}, + gaps = 5 + } + tt.bg = beautiful.bg_normal +end + +mouse.coords{x=125, y= 75} +mouse.push_history() +require("gears.timer").run_delayed_calls_now()