Merge pull request #2823 from Elv13/another_row_of_notification_fixes
naughty: Undocument naughty.notification.replaces_id.
This commit is contained in:
commit
1116bc47d0
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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.
|
||||||
|
|
Loading…
Reference in New Issue