From bfd5ba6a3cddeb1f66ac5f1454d0cc1fc66d1de8 Mon Sep 17 00:00:00 2001 From: zkk <1007518571@qq.com> Date: Fri, 14 Feb 2025 15:22:09 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BC=98=E5=8C=96=E7=BD=91=E7=BB=9C=E9=A1=B5?= =?UTF-8?q?=E9=9D=A2=E5=8D=A1=E9=A1=BF=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Squashed commit of the following: commit 2dba9f8ee2725847f31c891b19df6d9b81e03568 Merge: 03cd3722 18f05cc5 Author: zkk <1007518571@qq.com> Date: Fri Feb 14 15:21:36 2025 +0800 Merge commit '18f05cc52dfb7889853a4f84aad975309ab7dbbe' into release commit 18f05cc52dfb7889853a4f84aad975309ab7dbbe Author: zkk <1007518571@qq.com> Date: Wed Feb 5 10:59:00 2025 +0800 修复连接不了未加密网络的旧问题 commit 025a26209cbe15a0b7f5f1aba5166da63d6eaebf Author: zkk <1007518571@qq.com> Date: Fri Jan 24 15:48:52 2025 +0800 重构网络页面,解决卡顿问题 commit fdc851c4e66e3b872eb2564442f0c67369b9e3e2 Author: zkk <1007518571@qq.com> Date: Fri Jan 24 15:13:41 2025 +0800 优化菜单页面的点击效果和增加列表风格属性 commit e6cfa874208f8d98d0360fb073e4da15c935b202 Author: zkk <1007518571@qq.com> Date: Tue Jan 21 15:11:28 2025 +0800 优化进入工厂模式的方式为10s内点击5次 commit 03cd37229ee6c606e9814af602709d81b2c79bec Merge: cf7cafef adcbaa17 Author: zkk <1007518571@qq.com> Date: Fri Jan 17 14:38:18 2025 +0800 Merge commit 'adcbaa1795bffedc3000bc9e59eabba04d946dd4' into release commit adcbaa1795bffedc3000bc9e59eabba04d946dd4 Author: zkk <1007518571@qq.com> Date: Tue Jan 14 15:34:10 2025 +0800 实现探针偏移值校准保存前范围检测,避免保存错误值无法启动问题 commit cf7cafefbcd2274c9a481e58042d11db8cd79961 Merge: dc3478b4 8d259cea Author: zkk <1007518571@qq.com> Date: Tue Jan 7 17:26:59 2025 +0800 Merge commit '8d259ceadd5026cecc1dc61224d91aef4f3877b4' into release commit 8d259ceadd5026cecc1dc61224d91aef4f3877b4 Author: zkk <1007518571@qq.com> Date: Tue Jan 7 17:15:46 2025 +0800 实现 打印中恢复喷头温度 提示语的翻译 commit dd11c9683cb5af5407e650eea9b683b1066256c7 Author: zkk <1007518571@qq.com> Date: Tue Jan 7 16:52:04 2025 +0800 优化单个喷头时不显示喷头偏移菜单 commit c3ec7a81bbe1490b76202485d0502a4829a3cee5 Author: zkk <1007518571@qq.com> Date: Fri Jan 3 17:52:24 2025 +0800 修复屏幕耗材检测显示偶尔不准确的问题 commit 413bf6fc4a740f53d265c63abe7c51eaad483cb0 Author: zkk <1007518571@qq.com> Date: Fri Jan 3 15:00:54 2025 +0800 修复耗材检测弹窗异常问题 commit dc3478b48c7da1dbae120d1270c9ab64646d6647 Merge: 02c7556c 3bfc1aa7 Author: zkk <1007518571@qq.com> Date: Thu Jan 2 11:18:07 2025 +0800 Merge commit '3bfc1aa714e282d74b801155d830377ca58d8f59' into release commit 3bfc1aa714e282d74b801155d830377ca58d8f59 Author: zkk <1007518571@qq.com> Date: Thu Jan 2 11:17:15 2025 +0800 修复移轴页面移轴功能失效问题 commit 02c7556cdadf8de1ef3c54d2831920927cadbe30 Merge: 6bfa42e0 991003e6 Author: zkk <1007518571@qq.com> Date: Tue Dec 31 15:07:54 2024 +0800 Merge commit '991003e6cbea335eca73d3783aa1837059614724' into release commit 991003e6cbea335eca73d3783aa1837059614724 Author: zkk <1007518571@qq.com> Date: Tue Dec 31 15:03:34 2024 +0800 优化完整 简体中文和繁体中文的翻译 commit 1a177e90d09b9b9949bff2a1e3c6b12173420620 Author: zkk <1007518571@qq.com> Date: Tue Dec 31 14:10:03 2024 +0800 优化排除对象的英文语法错误 commit e8d509cb6c2883b1fadb5ab9f9ca658e61849055 Author: zkk <1007518571@qq.com> Date: Fri Dec 27 16:40:52 2024 +0800 优化耗材检测显示内容 commit 1b7670485a918cb334119175777525f768e670be Author: zkk <1007518571@qq.com> Date: Fri Dec 27 14:56:25 2024 +0800 完善断料自动切头功能描述 commit ecc0c3dd16442497e56f5f8ab3a0c6be00bd180e Author: zkk <1007518571@qq.com> Date: Fri Dec 27 13:40:01 2024 +0800 实现弹窗翻译功能 commit bc6d60fa183af50b7b16fea685139ca9d5df90ea Author: zkk <1007518571@qq.com> Date: Fri Dec 27 09:53:16 2024 +0800 优化不合理名称和不合理大小写 commit 2e650926bdba1c65baa506be1b1dd09621e8d8ea Author: zkk <1007518571@qq.com> Date: Thu Dec 26 15:06:11 2024 +0800 修复10寸屏幕偏移值微调页面出界问题 commit c481b551f777a3a6cadf7be3bfcab38448b51694 Author: zkk <1007518571@qq.com> Date: Wed Dec 25 15:28:26 2024 +0800 优化移轴设置页面没有返回按钮的问题 commit 2b3c9936bd693c8fc265d6352799f382680f4920 Author: zkk <1007518571@qq.com> Date: Wed Dec 25 10:05:04 2024 +0800 删除移动设置页面中轴反转的选项 commit 5e37d59497c54086d3f1e215cbabc03254857a58 Author: zkk <1007518571@qq.com> Date: Wed Dec 25 09:05:03 2024 +0800 优化选择语言标题 commit 5214c3697baac78bd0a465e33d6f4f3c1e30862e Author: zkk <1007518571@qq.com> Date: Tue Dec 24 10:57:41 2024 +0800 增加设置hostname功能 commit 3709a7465cc2e0d677ecc9979fb18144f7e0ec33 Author: zkk <1007518571@qq.com> Date: Tue Dec 24 10:43:46 2024 +0800 增加工厂设置中打包模式 commit 0c2a2618beb68d50601e433beef06122fb0ffd40 Author: zkk <1007518571@qq.com> Date: Mon Dec 23 16:25:37 2024 +0800 实现恢复出厂设置功能 commit e3a38f85613d53a4a063e835c34c701196010c6e Author: zkk <1007518571@qq.com> Date: Mon Dec 23 15:48:17 2024 +0800 一点格式化 commit 4e9e452e8bed4b53eaaae8f0a69142de8aa50611 Author: zkk <1007518571@qq.com> Date: Sat Dec 21 14:20:22 2024 +0800 优化探针偏移值校准时如果当前激活为第一个喷头时不会重复激活喷头 commit 3b85e8e8d59b0d4eae75f80d9e637fe9dc272cbe Merge: 882850db 10ec2029 Author: zkk <1007518571@qq.com> Date: Wed Dec 18 17:26:08 2024 +0800 Merge branch 'develop' of https://server.creatbot.com/Gitea/CreatBot/CreatBotKlipperScreen into develop commit 882850dbde648598e5f91281101d0ea01fd56d56 Author: zkk <1007518571@qq.com> Date: Wed Dec 18 17:21:16 2024 +0800 补充双喷头偏移校准页面二维码图片 commit 10ec2029eb73e66874d5a0ec492c016480641110 Author: ruipeng <1041589370@qq.com> Date: Wed Dec 18 17:17:18 2024 +0800 增加自动切换喷头开关选项 commit 3d6eed9d9526b77472ba7df29014b5768c594026 Author: zkk <1007518571@qq.com> Date: Mon Dec 16 16:33:34 2024 +0800 喷头偏移值校准功能的实现 commit 40ecbb3ea4827c9bac1aa271cccc958c94c1114a Author: zkk <1007518571@qq.com> Date: Fri Dec 13 09:20:00 2024 +0800 z探针校准时指定默认激活工具头为第一个头 commit bce3caa409618ef5bc2067865940d14a1441c0f8 Author: zkk <1007518571@qq.com> Date: Fri Dec 13 09:19:19 2024 +0800 优化z探针校准时候移动过慢问题 commit 6bfa42e036a521c8ff7db1bf8ccb65500eabb6ea Merge: 1a87ced3 4f3aa9aa Author: zkk <1007518571@qq.com> Date: Thu Dec 12 10:33:58 2024 +0800 Merge commit '4f3aa9aa4c581ae9e7a740bd37f9e80ba064c27f' into release commit 4f3aa9aa4c581ae9e7a740bd37f9e80ba064c27f Merge: e3fd413d 1a69b518 Author: zkk <1007518571@qq.com> Date: Thu Dec 12 10:30:00 2024 +0800 Merge branch 'develop' of https://server.creatbot.com/Gitea/CreatBot/CreatBotKlipperScreen into develop commit 1a69b5180de733f15550a1294a7221d6070306a0 Author: ruipeng <1041589370@qq.com> Date: Wed Dec 11 11:44:36 2024 +0800 新增D600pro2、D1000的V0版机型 commit e3fd413d6256414441e9fe653c1132b1799a5cb2 Author: zkk <1007518571@qq.com> Date: Tue Dec 10 14:34:13 2024 +0800 修复打印时没有修改z偏移值 仍提示保存z偏移的按钮的bug commit 594fb668fe94fe907c028bf65ecced43ea8660cb Author: zkk <1007518571@qq.com> Date: Tue Dec 10 14:25:04 2024 +0800 设置自适应调平选项默认为关闭状态 commit 1a87ced3f5725569a6b9a7ee5f5250044d01d852 Merge: 629416d1 6064a6e1 Author: zkk <1007518571@qq.com> Date: Fri Nov 29 10:18:32 2024 +0800 Merge branch 'develop' into release --- ks_includes/sdbus_nm.py | 56 ++++-- panels/network.py | 428 +++++++++++++++++++++------------------- panels/system.py | 4 +- styles/dark/style.css | 13 ++ styles/light/style.css | 12 ++ 5 files changed, 284 insertions(+), 229 deletions(-) diff --git a/ks_includes/sdbus_nm.py b/ks_includes/sdbus_nm.py index ac1525de..a8652749 100644 --- a/ks_includes/sdbus_nm.py +++ b/ks_includes/sdbus_nm.py @@ -175,23 +175,32 @@ class SdbusNm: networks = [] try: if self.wlan_device: + seen_networks = {} all_aps = [AccessPoint(result) for result in self.wlan_device.access_points] - networks.extend( - { - "SSID": ap.ssid.decode("utf-8"), - "known": self.is_known(ap.ssid.decode("utf-8")), - "security": get_encryption( - ap.rsn_flags or ap.wpa_flags or ap.flags - ), - "frequency": WifiChannels(ap.frequency)[0], - "channel": WifiChannels(ap.frequency)[1], - "signal_level": ap.strength, - "max_bitrate": ap.max_bitrate, - "BSSID": ap.hw_address, - } - for ap in all_aps - if ap.ssid - ) + for ap in all_aps: + if not ap.ssid: + continue + + ssid = ap.ssid.decode("utf-8") + signal_level = ap.strength + if ssid in seen_networks: + if signal_level > seen_networks[ssid]["signal_level"]: + seen_networks[ssid] = { + "SSID": ssid, + "known": self.is_known(ssid), + "security": get_encryption(ap.rsn_flags or ap.wpa_flags or ap.flags), + "signal_level": signal_level, + "BSSID": ap.hw_address, + } + else: + seen_networks[ssid] = { + "SSID": ssid, + "known": self.is_known(ssid), + "security": get_encryption(ap.rsn_flags or ap.wpa_flags or ap.flags), + "signal_level": signal_level, + "BSSID": ap.hw_address, + } + networks = list(seen_networks.values()) return sorted(networks, key=lambda i: i["signal_level"], reverse=True) return networks except Exception as e: @@ -200,6 +209,15 @@ class SdbusNm: def get_bssid_from_ssid(self, ssid): return next(net["BSSID"] for net in self.get_networks() if ssid == net["SSID"]) + def get_is_connected(self): + state = self.wlan_device.state + if state in [ + enums.DeviceState.ACTIVATED, + ]: + return True + else: + return False + def get_connected_ap(self): if self.wlan_device.active_access_point == "/": return None @@ -248,9 +266,7 @@ class SdbusNm: } if security_type == "Open": - properties["802-11-wireless-security"] = { - "key-mgmt": ("s", "none"), - } + properties["802-11-wireless"]["security"] = ("s", "none") elif "WPA-PSK" in security_type: properties["802-11-wireless-security"] = { "key-mgmt": ("s", "wpa-psk"), @@ -350,8 +366,6 @@ class SdbusNm: def connect(self, ssid): if target_connection := self.get_connection_path_by_ssid(ssid): - message = ssid + "\n" + _("Starting WiFi Association") - self.popup(message, 1) try: active_connection = self.nm.activate_connection(target_connection) return target_connection diff --git a/panels/network.py b/panels/network.py index 680a329c..e1215e7d 100644 --- a/panels/network.py +++ b/panels/network.py @@ -42,19 +42,28 @@ class Panel(ScreenPanel): self.content.add(self.error_box) self._screen.panels_reinit.append(self._screen._cur_panels[-1]) return - self.update_timeout = None - self.conn_status = None + self.reload_timer_id = None + self.monitor_timer_id = None + self.delay_reload_timer_id = None self.init_status = False self.reload = False - self.last_ap_bssid = '' - self.network_list = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, hexpand=True, vexpand=True) + self.last_state = None + self.network_list = Gtk.ListBox(selection_mode=Gtk.SelectionMode.NONE) self.network_rows = {} self.networks = {} self.wifi_signal_icons = { - 'excellent': self._gtk.PixbufFromIcon('wifi_excellent'), - 'good': self._gtk.PixbufFromIcon('wifi_good'), - 'fair': self._gtk.PixbufFromIcon('wifi_fair'), - 'weak': self._gtk.PixbufFromIcon('wifi_weak'), + "excellent": self._gtk.PixbufFromIcon( + "wifi_excellent", width=self._gtk.content_width * 0.06, height=self._gtk.content_height * 0.06 + ), + "good": self._gtk.PixbufFromIcon( + "wifi_good", width=self._gtk.content_width * 0.06, height=self._gtk.content_height * 0.06 + ), + "fair": self._gtk.PixbufFromIcon( + "wifi_fair", width=self._gtk.content_width * 0.06, height=self._gtk.content_height * 0.06 + ), + "weak": self._gtk.PixbufFromIcon( + "wifi_weak", width=self._gtk.content_width * 0.06, height=self._gtk.content_height * 0.06 + ), } self.network_interfaces = self.sdbus_nm.get_interfaces() @@ -74,7 +83,6 @@ class Panel(ScreenPanel): self.reload_button = self._gtk.Button("refresh", None, "custom-icon-button", self.bts) self.reload_button.set_no_show_all(True) - self.reload_button.show() self.reload_button.connect("clicked", self.reload_networks) self.reload_button.set_hexpand(False) @@ -96,82 +104,103 @@ class Panel(ScreenPanel): if self.sdbus_nm.wifi: self.labels['main_box'].pack_start(sbox, False, False, 5) - GLib.idle_add(self.load_networks) scroll.add(self.network_list) - self.sdbus_nm.enable_monitoring(True) - self.conn_status = GLib.timeout_add_seconds(1, self.sdbus_nm.monitor_connection_status) + if self.sdbus_nm.nm.wireless_enabled: + self.reload_button.show() + self.sdbus_nm.enable_monitoring(True) + self.monitor_timer_id = GLib.timeout_add(500, self.sdbus_nm.monitor_connection_status) else: self._screen.show_popup_message(_("No wireless interface has been found"), level=2) - self.labels['networkinfo'] = Gtk.Label() - scroll.add(self.labels['networkinfo']) + self.labels["networkinfo"] = Gtk.Label() + scroll.add(self.labels["networkinfo"]) self.update_single_network_info() - self.labels['main_box'].pack_start(scroll, True, True, 0) - self.content.add(self.labels['main_box']) + self.labels["main_box"].pack_start(scroll, True, True, 0) + self.content.add(self.labels["main_box"]) + self.network_list.connect("row-activated", self.handle_wifi_selection) def popup_callback(self, msg, level=3): - self._screen.show_popup_message(msg, level) + if not self.refresh_status(msg): + for item in self.network_rows: + if self.network_rows[item]["label_state"] is not None: + self.network_rows[item]["label_state"].set_no_show_all(True) + self.network_rows[item]["label_state"].hide() + self._screen.show_popup_message(msg, level) + + def handle_wifi_selection(self, list_box, row): + index = row.get_index() + logging.info(f"clicked SSID is {self.networks[index]['SSID']}") + self.connect_network(list_box, self.networks[index]["SSID"]) + + def add_network_item(self, ssid, lock, known, signal): + self.network_rows[ssid] = {} + self.network_rows[ssid]["row"] = Gtk.ListBoxRow() + self.network_rows[ssid]["hbox"] = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=15) + self.network_rows[ssid]["row"].add(self.network_rows[ssid]["hbox"]) + self.network_rows[ssid]["row"].get_style_context().add_class("frame-item") + + self.network_rows[ssid]["signal_ico"] = self._gtk.Image() + self.network_rows[ssid]["signal_ico"].set_from_pixbuf(self.get_signal_strength_icon(signal)) + self.network_rows[ssid]["signal_ico"].set_margin_start(50) + self.network_rows[ssid]["hbox"].pack_start(self.network_rows[ssid]["signal_ico"], False, True, 20) + + self.network_rows[ssid]["label_box"] = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, spacing=0) + self.network_rows[ssid]["label_ssid"] = Gtk.Label(label=ssid, xalign=0) + self.network_rows[ssid]["label_state"] = Gtk.Label(label="", xalign=0) + self.network_rows[ssid]["label_state"].set_ellipsize(Pango.EllipsizeMode.END) + self.network_rows[ssid]["label_state"].set_no_show_all(True) + self.network_rows[ssid]["label_box"].pack_start(self.network_rows[ssid]["label_ssid"], True, False, 0) + self.network_rows[ssid]["label_box"].pack_start(self.network_rows[ssid]["label_state"], True, False, 0) + self.network_rows[ssid]["hbox"].pack_start(self.network_rows[ssid]["label_box"], False, True, 10) + + if known: + self.network_rows[ssid]["delete"] = self._gtk.Button("delete", None, "custom-icon-button", self.bts) + self.network_rows[ssid]["delete"].connect("clicked", self.remove_confirm_dialog, ssid, ssid) + self.network_rows[ssid]["delete"].set_hexpand(False) + self.network_rows[ssid]["delete"].set_halign(Gtk.Align.END) + self.network_rows[ssid]["hbox"].pack_end(self.network_rows[ssid]["delete"], False, True, 10) + + if "Open" not in lock: + self.network_rows[ssid]["lock_image"] = self._gtk.Image( + "lock", self._gtk.content_width * 0.04, self._gtk.content_height * 0.04 + ) + self.network_rows[ssid]["lock_image"].set_hexpand(False) + self.network_rows[ssid]["lock_image"].set_halign(Gtk.Align.END) + self.network_rows[ssid]["hbox"].pack_end(self.network_rows[ssid]["lock_image"], False, True, 10) + + self.network_rows[ssid]["hbox"].set_margin_end(50) + self.network_list.add(self.network_rows[ssid]["row"]) + + def move_network_to_front(self, networks, target_name): + if not target_name or (networks and networks[0].get("SSID") == target_name): + return networks + target_index = next((i for i, network in enumerate(networks) if network.get("SSID") == target_name), None) + if target_index is not None: + target_network = networks.pop(target_index) + networks.insert(0, target_network) + return networks def load_networks(self): - GLib.timeout_add_seconds(10, self._gtk.Button_busy, self.reload_button, False) - self.content.show_all() - return False + self.connected_ap = self.sdbus_nm.get_connected_ap() + ap_ssid = None + if self.connected_ap: + ap_ssid = self.connected_ap.ssid.decode("utf-8") + self.networks = self.move_network_to_front(self.sdbus_nm.get_networks(), ap_ssid) + if self.last_state != self.sdbus_nm.wifi_state: + self.last_state = self.sdbus_nm.wifi_state + self.sdbus_nm.wifi_state = -1 + self.sdbus_nm.monitor_connection_status() - def add_network(self, bssid): - if bssid in self.network_rows: - return - - networks = self.sdbus_nm.get_networks() - if networks: - net = next((net for net in networks if bssid == net['BSSID']), None) - if net is None: - self.remove_network_from_list(bssid) - return - - ssid = net['SSID'] - - connect = self._gtk.Button("load", None, "color3", self.bts) - connect.connect("clicked", self.connect_network, ssid) - connect.set_hexpand(False) - connect.set_halign(Gtk.Align.END) - - delete = self._gtk.Button("delete", None, "color3", self.bts) - delete.connect("clicked", self.remove_confirm_dialog, ssid, bssid) - delete.set_hexpand(False) - delete.set_halign(Gtk.Align.END) - - buttons = Gtk.Box(spacing=5) - - name = Gtk.Label(hexpand=True, halign=Gtk.Align.START, wrap=True, wrap_mode=Pango.WrapMode.WORD_CHAR) - if bssid == self.sdbus_nm.get_connected_bssid(): - ssid += ' (' + _("Connected") + ')' - name.set_markup(f"{ssid}") - else: - name.set_markup(f"{ssid}") - if net['known']: - buttons.add(delete) - buttons.add(connect) - - labels = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, vexpand=True, - halign=Gtk.Align.START, valign=Gtk.Align.CENTER) - labels.add(name) - icon = self._gtk.Image() - - self.network_rows[bssid] = Gtk.Box(spacing=5, hexpand=True, vexpand=False) - self.network_rows[bssid].get_style_context().add_class("frame-item") - self.network_rows[bssid].add(icon) - self.network_rows[bssid].add(labels) - self.network_rows[bssid].add(buttons) - - self.networks[bssid] = { - "connect": connect, - "delete": delete, - "icon": icon, - "name": name, - "row": self.network_rows[bssid], - } - - self.network_list.add(self.network_rows[bssid]) + for item in self.networks: + ssid = item.get("SSID") + if ssid: + self.add_network_item( + ssid, + item.get("security", "unknown"), + item.get("known", False), + item.get("signal_level", 0), + ) + self.network_list.show_all() def remove_confirm_dialog(self, widget, ssid, bssid): @@ -189,21 +218,20 @@ class Panel(ScreenPanel): self._gtk.remove_dialog(dialog) if response_id == Gtk.ResponseType.CANCEL: return - bssid = self.sdbus_nm.get_bssid_from_ssid(ssid) - self.remove_network_from_list(bssid) if response_id == Gtk.ResponseType.OK: logging.info(f"Deleting {ssid}") self.sdbus_nm.delete_network(ssid) if response_id == Gtk.ResponseType.APPLY: logging.info(f"Disconnecting {ssid}") self.sdbus_nm.disconnect_network() + self.delay_reload_networks(100) def add_new_network(self, widget, ssid): self._screen.remove_keyboard() - psk = self.labels['network_psk'].get_text() - identity = self.labels['network_identity'].get_text() - eap_method = self.get_dropdown_value(self.labels['network_eap_method']) - phase2 = self.get_dropdown_value(self.labels['network_phase2']) + psk = self.labels["network_psk"].get_text() + identity = self.labels["network_identity"].get_text() + eap_method = self.get_dropdown_value(self.labels["network_eap_method"]) + phase2 = self.get_dropdown_value(self.labels["network_phase2"]) logging.debug(f"{phase2=}") logging.debug(f"{eap_method=}") result = self.sdbus_nm.add_network(ssid, psk, eap_method, identity, phase2) @@ -240,36 +268,37 @@ class Panel(ScreenPanel): del self.labels[i] self.show_add = False + def get_network_index(self, ssid): + for index, network in enumerate(self.networks): + if network.get("SSID") == ssid: + return index + return -1 + def connect_network(self, widget, ssid, showadd=True): - self.deactivate() - if showadd and not self.sdbus_nm.is_known(ssid): - sec_type = self.sdbus_nm.get_security_type(ssid) + index = self.get_network_index(ssid) + ssid = self.networks[index]["SSID"] + if showadd and not self.networks[index]["known"]: # self.sdbus_nm.is_known(ssid): + sec_type = self.networks[index]["security"] # self.sdbus_nm.get_security_type(ssid) if sec_type == "Open" or "OWE" in sec_type: logging.debug("Network is Open do not show psk") - result = self.sdbus_nm.add_network(ssid, '') + result = self.sdbus_nm.add_network(ssid, "", "") + self.sdbus_nm.connect(ssid) if "error" in result: self._screen.show_popup_message(result["message"]) else: self.show_add_network(widget, ssid) - self.activate() return - bssid = self.sdbus_nm.get_bssid_from_ssid(ssid) - if bssid and bssid in self.network_rows: - self.remove_network_from_list(bssid) self.sdbus_nm.connect(ssid) - self.reload_networks() - if self.conn_status is None: + self.delay_reload_networks(1000) + if self.monitor_timer_id is None: self.sdbus_nm.enable_monitoring(True) - self.conn_status = GLib.timeout_add(500, self.sdbus_nm.monitor_connection_status) + self.monitor_timer_id = GLib.timeout_add(500, self.sdbus_nm.monitor_connection_status) - def remove_network_from_list(self, bssid): - if bssid not in self.network_rows: - logging.error(f"{bssid} not in rows") - return - self.network_list.remove(self.network_rows[bssid]) - del self.network_rows[bssid] - del self.networks[bssid] - return + def remove_network_list(self): + for row in self.network_list.get_children(): + self.network_list.remove(row) + row.destroy() + self.network_rows.clear() def show_add_network(self, widget, ssid): if self.show_add: @@ -277,174 +306,161 @@ class Panel(ScreenPanel): for child in self.content.get_children(): self.content.remove(child) - if "add_network" in self.labels: - del self.labels['add_network'] - + del self.labels["add_network"] eap_method = Gtk.ComboBoxText(hexpand=True) for method in ("peap", "ttls", "pwd", "leap", "md5"): eap_method.append(method, method.upper()) - self.labels['network_eap_method'] = eap_method + self.labels["network_eap_method"] = eap_method eap_method.set_active(0) phase2 = Gtk.ComboBoxText(hexpand=True) for method in ("mschapv2", "gtc", "pap", "chap", "mschap", "disabled"): phase2.append(method, method.upper()) - self.labels['network_phase2'] = phase2 + self.labels["network_phase2"] = phase2 phase2.set_active(0) - auth_selection_box = Gtk.Box(no_show_all=True) - auth_selection_box.add(self.labels['network_eap_method']) - auth_selection_box.add(self.labels['network_phase2']) + self.labels["network_identity"] = Gtk.Entry(hexpand=True, no_show_all=True) + self.labels["network_identity"].connect("focus-in-event", self._screen.show_keyboard) - self.labels['network_identity'] = Gtk.Entry(hexpand=True, no_show_all=True) - self.labels['network_identity'].connect("focus-in-event", self._screen.show_keyboard) + self.labels["network_psk"] = Gtk.Entry(hexpand=True) + self.labels["network_psk"].set_visibility(False) + self.labels["network_psk"].connect("activate", self.add_new_network, ssid) + self.labels["network_psk"].connect("focus-in-event", self._screen.show_keyboard) - self.labels['network_psk'] = Gtk.Entry(hexpand=True) - self.labels['network_psk'].connect("activate", self.add_new_network, ssid) - self.labels['network_psk'].connect("focus-in-event", self._screen.show_keyboard) - - save = self._gtk.Button("sd", _("Save"), "color3") + save = self._gtk.Button("load", style="color3") save.set_hexpand(False) save.connect("clicked", self.add_new_network, ssid) user_label = Gtk.Label(label=_("User"), hexpand=False, no_show_all=True) auth_grid = Gtk.Grid() auth_grid.attach(user_label, 0, 0, 1, 1) - auth_grid.attach(self.labels['network_identity'], 1, 0, 1, 1) + auth_grid.attach(self.labels["network_identity"], 1, 0, 1, 1) auth_grid.attach(Gtk.Label(label=_("Password"), hexpand=False), 0, 1, 1, 1) - auth_grid.attach(self.labels['network_psk'], 1, 1, 1, 1) + auth_grid.attach(self.labels["network_psk"], 1, 1, 1, 1) auth_grid.attach(save, 2, 0, 1, 2) - if "802.1x" in self.sdbus_nm.get_security_type(ssid): - user_label.show() - self.labels['network_eap_method'].show() - self.labels['network_phase2'].show() - self.labels['network_identity'].show() - auth_selection_box.show() - - self.labels['add_network'] = Gtk.Box( - orientation=Gtk.Orientation.VERTICAL, spacing=5, valign=Gtk.Align.CENTER, - hexpand=True, vexpand=True + self.labels["add_network"] = Gtk.Box( + orientation=Gtk.Orientation.VERTICAL, spacing=5, valign=Gtk.Align.CENTER, hexpand=True, vexpand=True ) - self.labels['add_network'].add(Gtk.Label(label=_("Connecting to %s") % ssid)) - self.labels['add_network'].add(auth_selection_box) - self.labels['add_network'].add(auth_grid) + self.labels["add_network"].add(Gtk.Label(label=_("Connecting to %s") % ssid)) + self.labels["add_network"].add(auth_grid) scroll = self._gtk.ScrolledWindow() - scroll.add(self.labels['add_network']) + scroll.add(self.labels["add_network"]) self.content.add(scroll) - self.labels['network_psk'].grab_focus_without_selecting() + self.labels["network_psk"].grab_focus_without_selecting() self.content.show_all() self.show_add = True - def update_all_networks(self): - self.ap_bssid = self.sdbus_nm.get_connected_bssid() - if self.last_ap_bssid != self.ap_bssid: - self.remove_network_from_list(self.last_ap_bssid) - self.remove_network_from_list(self.ap_bssid) - self.last_ap_bssid = self.ap_bssid - - if self.reload: - for child in self.network_list.get_children(): - self.network_list.remove(child) - self.reload = False - - self.interface = self.sdbus_nm.get_primary_interface() - self.labels['interface'].set_text(_("Interface") + f': {self.interface}') - self.labels['ip'].set_text(f"IP: {self.sdbus_nm.get_ip_address()}") - nets = self.sdbus_nm.get_networks() - remove = [bssid for bssid in self.network_rows.keys() if bssid not in [net['BSSID'] for net in nets]] - for bssid in remove: - self.remove_network_from_list(bssid) - for net in nets: - if net['BSSID'] not in self.network_rows.keys(): - self.add_network(net['BSSID']) - self.update_network_info(net) - for i, net in enumerate(nets): - for child in self.network_list.get_children(): - if 'BSSID' in net and net['BSSID'] in self.network_rows: - if child == self.network_rows[net['BSSID']]: - self.network_list.reorder_child(child, i) - self.network_list.show_all() - return True - - def update_network_info(self, net): - if net['BSSID'] not in self.network_rows.keys() or net['BSSID'] not in self.networks: - logging.info(f"Unknown SSID {net['SSID']}") - return - self.networks[net['BSSID']]['icon'].set_from_pixbuf(self.get_signal_strength_icon(net["signal_level"])) - def get_signal_strength_icon(self, signal_level): # networkmanager uses percentage not dbm if signal_level > 75: - return self.wifi_signal_icons['excellent'] + return self.wifi_signal_icons["excellent"] elif signal_level > 60: - return self.wifi_signal_icons['good'] + return self.wifi_signal_icons["good"] elif signal_level > 30: - return self.wifi_signal_icons['fair'] + return self.wifi_signal_icons["fair"] else: - return self.wifi_signal_icons['weak'] + return self.wifi_signal_icons["weak"] - def update_single_network_info(self): - self.labels['networkinfo'].set_markup( - f'{self.interface}\n\n' - + '' + _("Hostname") + f': {os.uname().nodename}\n' - f'IPv4: {self.sdbus_nm.get_ip_address()}\n' - ) - self.labels['networkinfo'].show_all() - return True + def refresh_status(self, state=None): + if state: + self.connected_ap = self.sdbus_nm.get_connected_ap() + if self.connected_ap: + ap_ssid = self.connected_ap.ssid.decode("utf-8") + self.set_connect_state(ap_ssid, state) + return True + else: + return False + + def set_connect_state(self, ssid, state): + for item in self.network_rows: + if self.network_rows[item]["label_state"] is not None: + self.network_rows[item]["label_state"].set_no_show_all(True) + self.network_rows[item]["label_state"].hide() + if ssid and state and ssid in self.network_rows: + if self.network_rows[ssid]["label_state"] is not None: + self.network_rows[ssid]["label_state"].set_markup(f'{state}') + self.network_rows[ssid]["label_state"].set_no_show_all(False) + self.network_list.show_all() def reload_networks(self, widget=None): - self.deactivate() + if self.reload: + return + self.reload = True + self.remove_network_list() del self.network_rows self.network_rows = {} if self.sdbus_nm is not None and self.sdbus_nm.wifi: - if widget: - self._gtk.Button_busy(widget, True) + self._gtk.Button_busy(self.reload_button, True) if not self.init_status: self.sdbus_nm.rescan() else: self.init_status = False self.load_networks() - self.activate() - self.reload = True + if self.sdbus_nm.get_is_connected(): + self.refresh_status(_('Network connected')) + + self._gtk.Button_busy(self.reload_button, False) + self.reload = False + + if self.delay_reload_timer_id: + GLib.source_remove(self.delay_reload_timer_id) + self.delay_reload_timer_id = None + + return self.sdbus_nm.nm.wireless_enabled + + def delay_reload_networks(self, s): + self._gtk.Button_busy(self.reload_button, True) + if not self.delay_reload_timer_id: + self.delay_reload_timer_id = GLib.timeout_add(s, self.reload_networks) + + def start_refresh_timer(self): + if not self.sdbus_nm.monitor_connection_status(): + self.sdbus_nm.enable_monitoring(True) + if self.monitor_timer_id is None: + self.monitor_timer_id = GLib.timeout_add(600, self.sdbus_nm.monitor_connection_status) + if self.reload_timer_id is None: + self.reload_timer_id = GLib.timeout_add_seconds(10, self.reload_networks) + return False + + def stop_refresh_timer(self): + if self.monitor_timer_id is not None: + self.sdbus_nm.enable_monitoring(False) + GLib.source_remove(self.monitor_timer_id) + self.monitor_timer_id = None + if self.reload_timer_id is not None: + GLib.source_remove(self.reload_timer_id) + self.reload_timer_id = None def activate(self): if self.sdbus_nm is None: return - if self.update_timeout is None: - if self.sdbus_nm.wifi: - if self.sdbus_nm.is_wifi_enabled(): - if self.reload_button.get_sensitive(): - self._gtk.Button_busy(self.reload_button, True) - self.sdbus_nm.rescan() - self.load_networks() - self.update_timeout = GLib.timeout_add_seconds(5, self.update_all_networks) - else: - self.update_single_network_info() - self.update_timeout = GLib.timeout_add_seconds(5, self.update_single_network_info) + if self.sdbus_nm.wifi: + if self.sdbus_nm.is_wifi_enabled(): + self.delay_reload_networks(1000) + self.start_refresh_timer() def deactivate(self): if self.sdbus_nm is None: return - if self.update_timeout is not None: - GLib.source_remove(self.update_timeout) - self.update_timeout = None - if self.sdbus_nm.wifi: - self.sdbus_nm.enable_monitoring(False) - if self.conn_status is not None: - GLib.source_remove(self.conn_status) - self.conn_status = None + self.stop_refresh_timer() def toggle_wifi(self, switch, gparams): enable = switch.get_active() logging.info(f"WiFi {enable}") self.sdbus_nm.toggle_wifi(enable) if enable: + self.reload_button.set_no_show_all(False) self.reload_button.show() + self.network_list.set_no_show_all(False) self.network_list.show() self.init_status = True - self.reload_networks(self.reload_button) + self.delay_reload_networks(3000) + self.start_refresh_timer() else: + self.stop_refresh_timer() + self.reload_button.set_no_show_all(True) self.reload_button.hide() + self.network_list.set_no_show_all(True) self.network_list.hide() diff --git a/panels/system.py b/panels/system.py index 2a3c151b..c9e514df 100644 --- a/panels/system.py +++ b/panels/system.py @@ -18,8 +18,8 @@ class Panel(ScreenPanel): self.labels = {} self.click_count = 0 self.last_click_time = 0 - self.click_threshold = 0.2 - self.target_clicks = 10 + self.click_threshold = 2.0 + self.target_clicks = 5 self.grid = Gtk.Grid(column_spacing=10, row_spacing=5) self.sysinfo = screen.printer.system_info diff --git a/styles/dark/style.css b/styles/dark/style.css index ae63ec56..ef988248 100644 --- a/styles/dark/style.css +++ b/styles/dark/style.css @@ -33,6 +33,7 @@ color: @yellow-opa-100; } +list, list row, treeview.view, window { @@ -105,6 +106,18 @@ button.invalid:active, border-color: @blue-opa-50; } +button.color1:hover, +button.color2:hover, +button.color3:hover, +button.color4:hover, +button.update:hover, +button.invalid:hover, +.dialog button:hover, +row:hover { + background-color: @blue-opa-50; + border-color: @blue-opa-50; +} + button.active { background-color: @white-opa-20; } diff --git a/styles/light/style.css b/styles/light/style.css index 56f76948..48417f8d 100644 --- a/styles/light/style.css +++ b/styles/light/style.css @@ -19,6 +19,7 @@ color: @text ; } +list, list row, treeview.view, window { @@ -117,6 +118,17 @@ button.invalid:active, background-color: @active; } +row:hover, +button.color1:hover, +button.color2:hover, +button.color3:hover, +button.color4:hover, +button.update:hover, +button.invalid:hover, +.dialog button:hover { + background-color: @active; +} + button.active { background-color: @active; }