pop up a desktop notification if the battery is below 5%
This commit is contained in:
		
							parent
							
								
									7ae24488d9
								
							
						
					
					
						commit
						ef62892f60
					
				|  | @ -46,6 +46,9 @@ _STATUS_TIMEOUT = 120  # seconds | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| class ReceiverStatus(dict): | class ReceiverStatus(dict): | ||||||
|  | 	"""The 'runtime' status of a receiver, mostly about the pairing process -- | ||||||
|  | 	is the pairing lock open or closed, any pairing errors, etc. | ||||||
|  | 	""" | ||||||
| 	def __init__(self, receiver, changed_callback): | 	def __init__(self, receiver, changed_callback): | ||||||
| 		assert receiver | 		assert receiver | ||||||
| 		self._receiver = _proxy(receiver) | 		self._receiver = _proxy(receiver) | ||||||
|  | @ -95,6 +98,10 @@ class ReceiverStatus(dict): | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| class DeviceStatus(dict): | class DeviceStatus(dict): | ||||||
|  | 	"""Holds the 'runtime' status of a peripheral -- things like | ||||||
|  | 	active/inactive, battery charge, lux, etc. It updates them mostly by | ||||||
|  | 	processing incoming notification events from the device itself. | ||||||
|  | 	""" | ||||||
| 	def __init__(self, device, changed_callback): | 	def __init__(self, device, changed_callback): | ||||||
| 		assert device | 		assert device | ||||||
| 		self._device = _proxy(device) | 		self._device = _proxy(device) | ||||||
|  | @ -115,7 +122,7 @@ class DeviceStatus(dict): | ||||||
| 			battery_level = _item(BATTERY_LEVEL, 'Battery: %d%%') | 			battery_level = _item(BATTERY_LEVEL, 'Battery: %d%%') | ||||||
| 			if battery_level: | 			if battery_level: | ||||||
| 				yield battery_level | 				yield battery_level | ||||||
| 				battery_status = _item(BATTERY_STATUS, ' <small>(%s)</small>') | 				battery_status = _item(BATTERY_STATUS, ' (%s)') | ||||||
| 				if battery_status: | 				if battery_status: | ||||||
| 					yield battery_status | 					yield battery_status | ||||||
| 
 | 
 | ||||||
|  | @ -143,10 +150,10 @@ class DeviceStatus(dict): | ||||||
| 		changed = old_level != level or old_status != status | 		changed = old_level != level or old_status != status | ||||||
| 		alert, reason = ALERT.NONE, None | 		alert, reason = ALERT.NONE, None | ||||||
| 
 | 
 | ||||||
| 		if not _hidpp20.BATTERY_OK(status): | 		if not _hidpp20.BATTERY_OK(status) or level <= 5: | ||||||
| 			_log.warn("%s: battery %d%% charged, ALERT %s", self._device, level, status) | 			_log.warn("%s: battery %d%% charged, ALERT %s", self._device, level, status) | ||||||
| 			alert = ALERT.NOTIFICATION | 			alert = ALERT.NOTIFICATION | ||||||
| 			reason = status | 			reason = 'Battery: %d%% (%s)' % (level, status) | ||||||
| 
 | 
 | ||||||
| 		if changed or reason: | 		if changed or reason: | ||||||
| 			self._changed(alert=alert, reason=reason, timestamp=timestamp) | 			self._changed(alert=alert, reason=reason, timestamp=timestamp) | ||||||
|  | @ -175,11 +182,16 @@ class DeviceStatus(dict): | ||||||
| 		assert self._changed_callback | 		assert self._changed_callback | ||||||
| 		was_active, self._active = self._active, active | 		was_active, self._active = self._active, active | ||||||
| 		if active: | 		if active: | ||||||
|  | 			# Make sure to set notification flags on the device, they | ||||||
|  | 			# get cleared when the device is turned off (but not when the device | ||||||
|  | 			# goes idle, and we can't tell the difference right now). | ||||||
| 			if not was_active: | 			if not was_active: | ||||||
| 				self._device.enable_notifications() | 				self._device.enable_notifications() | ||||||
| 		else: | 		else: | ||||||
| 			battery = self.get(BATTERY_LEVEL) | 			battery = self.get(BATTERY_LEVEL) | ||||||
| 			self.clear() | 			self.clear() | ||||||
|  | 			# if we had a known battery level before, assume it's not going | ||||||
|  | 			# to change much while the device is offline | ||||||
| 			if battery is not None: | 			if battery is not None: | ||||||
| 				self[BATTERY_LEVEL] = battery | 				self[BATTERY_LEVEL] = battery | ||||||
| 
 | 
 | ||||||
|  | @ -198,6 +210,9 @@ class DeviceStatus(dict): | ||||||
| 				_log.error("polling status of invalid device") | 				_log.error("polling status of invalid device") | ||||||
| 				return | 				return | ||||||
| 
 | 
 | ||||||
|  | 			if _log.isEnabledFor(_DEBUG): | ||||||
|  | 				_log.debug("polling status of %s", d) | ||||||
|  | 
 | ||||||
| 			# read these from the device in case they haven't been read already | 			# read these from the device in case they haven't been read already | ||||||
| 			# d.protocol, d.serial, d.firmware | 			# d.protocol, d.serial, d.firmware | ||||||
| 
 | 
 | ||||||
|  | @ -321,7 +336,8 @@ class DeviceStatus(dict): | ||||||
| 			if n.address == 0x01: | 			if n.address == 0x01: | ||||||
| 				if _log.isEnabledFor(_DEBUG): | 				if _log.isEnabledFor(_DEBUG): | ||||||
| 					_log.debug("%s: device powered on", self._device) | 					_log.debug("%s: device powered on", self._device) | ||||||
| 				self._changed(alert=ALERT.NOTIFICATION, reason='powered on') | 				reason = str(self) or 'powered on' | ||||||
|  | 				self._changed(alert=ALERT.NOTIFICATION, reason=reason) | ||||||
| 			else: | 			else: | ||||||
| 				_log.info("%s: unknown %s", self._device, n) | 				_log.info("%s: unknown %s", self._device, n) | ||||||
| 			return True | 			return True | ||||||
|  |  | ||||||
|  | @ -71,8 +71,8 @@ class ReceiverListener(_listener.EventsListener): | ||||||
| 		self.status_changed_callback(r)  #, _status.ALERT.NOTIFICATION) | 		self.status_changed_callback(r)  #, _status.ALERT.NOTIFICATION) | ||||||
| 
 | 
 | ||||||
| 	def tick(self, timestamp): | 	def tick(self, timestamp): | ||||||
| 		if _log.isEnabledFor(_DEBUG): | 		# if _log.isEnabledFor(_DEBUG): | ||||||
| 			_log.debug("%s: polling status: %s", self.receiver, list(iter(self.receiver))) | 		# 	_log.debug("%s: polling status: %s", self.receiver, list(iter(self.receiver))) | ||||||
| 
 | 
 | ||||||
| 		# if self._last_tick > 0 and timestamp - self._last_tick > _POLL_TICK * 2: | 		# if self._last_tick > 0 and timestamp - self._last_tick > _POLL_TICK * 2: | ||||||
| 		# 	# if we missed a couple of polls, most likely the computer went into | 		# 	# if we missed a couple of polls, most likely the computer went into | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue