Merge pull request #2823 from Elv13/another_row_of_notification_fixes

naughty: Undocument naughty.notification.replaces_id.
This commit is contained in:
Emmanuel Lepage Vallée 2019-07-12 16:00:20 -04:00 committed by GitHub
commit 1116bc47d0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 34 additions and 8 deletions

View File

@ -126,9 +126,18 @@ gtable.crush(naughty, require("naughty.constants"))
-- @property has_display_handler -- @property has_display_handler
-- @param boolean -- @param boolean
--- If the timeout needs to be reset when a property changes.
--
-- This is the global variant of the `naughty.notification` `auto_reset_timeout`
-- property.
--
-- @property auto_reset_timeout
-- @tparam[opt=true] boolean auto_reset_timeout
local properties = { local properties = {
suspended = false, suspended = false,
expiration_paused = false expiration_paused = false,
auto_reset_timeout= true,
} }
--TODO v5 Deprecate the public `naughty.notifications` (to make it private) --TODO v5 Deprecate the public `naughty.notifications` (to make it private)

View File

@ -236,6 +236,9 @@ function notif_methods.Notify(sender, object_path, interface, method, parameters
if k == "destroy" then k = "destroy_cb" end if k == "destroy" then k = "destroy_cb" end
notification[k] = v notification[k] = v
end end
-- Even if no property changed, restart the timeout.
notification:reset_timeout()
else else
notification = nnotif(args) notification = nnotif(args)
end end

View File

@ -235,10 +235,6 @@ local notification = {}
-- @property preset -- @property preset
-- @param table -- @param table
--- Replace the notification with the given ID.
-- @property replaces_id
-- @param number
--- Function that will be called with all arguments. --- Function that will be called with all arguments.
-- The notification will only be displayed if the function returns true. -- The notification will only be displayed if the function returns true.
-- Note: this function is only relevant to notifications sent via dbus. -- Note: this function is only relevant to notifications sent via dbus.
@ -271,6 +267,14 @@ local notification = {}
-- @param boolean -- @param boolean
-- @see naughty.expiration_paused -- @see naughty.expiration_paused
--- If the timeout needs to be reset when a property changes.
--
-- By default it fallsback to `naughty.auto_reset_timeout`, which itself is
-- true by default.
--
-- @property auto_reset_timeout
-- @tparam[opt=true] boolean auto_reset_timeout
--- Emitted when the notification is destroyed. --- Emitted when the notification is destroyed.
-- @signal destroyed -- @signal destroyed
-- @tparam number reason Why it was destroyed -- @tparam number reason Why it was destroyed
@ -394,8 +398,8 @@ local properties = {
"width" , "font" , "icon" , "icon_size" , "width" , "font" , "icon" , "icon_size" ,
"fg" , "bg" , "height" , "border_color" , "fg" , "bg" , "height" , "border_color" ,
"shape" , "opacity" , "margin" , "ignore_suspend", "shape" , "opacity" , "margin" , "ignore_suspend",
"destroy" , "preset" , "callback", "replaces_id" , "destroy" , "preset" , "callback", "actions" ,
"actions" , "run" , "id" , "ignore" , "run" , "id" , "ignore" , "auto_reset_timeout"
} }
for _, prop in ipairs(properties) do for _, prop in ipairs(properties) do
@ -412,6 +416,17 @@ for _, prop in ipairs(properties) do
notification["set_"..prop] = notification["set_"..prop] or function(self, value) notification["set_"..prop] = notification["set_"..prop] or function(self, value)
self._private[prop] = value self._private[prop] = value
self:emit_signal("property::"..prop, value) self:emit_signal("property::"..prop, value)
-- When a notification is updated over dbus or by setting a property,
-- it is usually convenient to reset the timeout.
local reset = ((not self.suspended)
and self.auto_reset_timeout ~= false
and naughty.auto_reset_timeout)
if reset then
self:reset_timeout()
end
return return
end end
@ -496,7 +511,6 @@ end
-- @tparam[opt] table args.preset Table with any of the above parameters. -- @tparam[opt] table args.preset Table with any of the above parameters.
-- Note: Any parameters specified directly in args will override ones defined -- Note: Any parameters specified directly in args will override ones defined
-- in the preset. -- in the preset.
-- @tparam[opt] int args.replaces_id Replace the notification with the given ID.
-- @tparam[opt] func args.callback Function that will be called with all arguments. -- @tparam[opt] func args.callback Function that will be called with all arguments.
-- The notification will only be displayed if the function returns true. -- The notification will only be displayed if the function returns true.
-- Note: this function is only relevant to notifications sent via dbus. -- Note: this function is only relevant to notifications sent via dbus.