mirror of
https://github.com/noctalia-dev/noctalia-shell.git
synced 2026-05-11 17:08:27 +08:00
162 lines
5.7 KiB
QML
162 lines
5.7 KiB
QML
import QtQuick
|
||
import QtQuick.Controls
|
||
import Quickshell
|
||
import qs.Commons
|
||
import qs.Modules.Bar.Extras
|
||
import qs.Modules.Panels.Settings // For SettingsPanel
|
||
import qs.Services.Networking
|
||
import qs.Services.UI
|
||
import qs.Widgets
|
||
|
||
Item {
|
||
id: root
|
||
|
||
property ShellScreen screen
|
||
|
||
// Widget properties passed from Bar.qml for per-instance settings
|
||
property string widgetId: ""
|
||
property string section: ""
|
||
property int sectionWidgetIndex: -1
|
||
property int sectionWidgetsCount: 0
|
||
|
||
property var widgetMetadata: BarWidgetRegistry.widgetMetadata[widgetId]
|
||
// Explicit screenName property ensures reactive binding when screen changes
|
||
readonly property string screenName: screen ? screen.name : ""
|
||
property var widgetSettings: {
|
||
if (section && sectionWidgetIndex >= 0 && screenName) {
|
||
var widgets = Settings.getBarWidgetsForScreen(screenName)[section];
|
||
if (widgets && sectionWidgetIndex < widgets.length) {
|
||
return widgets[sectionWidgetIndex];
|
||
}
|
||
}
|
||
return {};
|
||
}
|
||
|
||
readonly property string barPosition: Settings.getBarPositionForScreen(screenName)
|
||
readonly property bool isBarVertical: barPosition === "left" || barPosition === "right"
|
||
readonly property string displayMode: widgetSettings.displayMode !== undefined ? widgetSettings.displayMode : widgetMetadata.displayMode
|
||
readonly property string iconColorKey: widgetSettings.iconColor !== undefined ? widgetSettings.iconColor : widgetMetadata.iconColor
|
||
readonly property string textColorKey: widgetSettings.textColor !== undefined ? widgetSettings.textColor : widgetMetadata.textColor
|
||
|
||
implicitWidth: pill.width
|
||
implicitHeight: pill.height
|
||
|
||
NPopupContextMenu {
|
||
id: contextMenu
|
||
|
||
model: [
|
||
{
|
||
"label": Settings.data.network.wifiEnabled ? I18n.tr("actions.disable-wifi") : I18n.tr("actions.enable-wifi"),
|
||
"action": "toggle-wifi",
|
||
"icon": Settings.data.network.wifiEnabled ? "wifi-off" : "wifi",
|
||
"enabled": !Settings.data.network.airplaneModeEnabled && NetworkService.wifiAvailable
|
||
},
|
||
{
|
||
"label": I18n.tr("common.wifi") + " " + I18n.tr("tooltips.open-settings"),
|
||
"action": "wifi-settings",
|
||
"icon": "settings"
|
||
},
|
||
{
|
||
"label": I18n.tr("actions.widget-settings"),
|
||
"action": "widget-settings",
|
||
"icon": "settings"
|
||
},
|
||
]
|
||
|
||
onTriggered: action => {
|
||
contextMenu.close();
|
||
PanelService.closeContextMenu(screen);
|
||
|
||
if (action === "toggle-wifi") {
|
||
NetworkService.setWifiEnabled(!Settings.data.network.wifiEnabled);
|
||
} else if (action === "wifi-settings") {
|
||
SettingsPanelService.openToTab(SettingsPanel.Tab.Connections, 0, screen);
|
||
} else if (action === "widget-settings") {
|
||
BarService.openWidgetSettings(screen, section, sectionWidgetIndex, widgetId, widgetSettings);
|
||
}
|
||
}
|
||
}
|
||
|
||
BarPill {
|
||
id: pill
|
||
|
||
screen: root.screen
|
||
oppositeDirection: BarService.getPillDirection(root)
|
||
customIconColor: Color.resolveColorKeyOptional(root.iconColorKey)
|
||
customTextColor: Color.resolveColorKeyOptional(root.textColorKey)
|
||
icon: {
|
||
try {
|
||
if (NetworkService.ethernetConnected) {
|
||
return NetworkService.internetConnectivity ? "ethernet" : "ethernet-off";
|
||
}
|
||
let connected = false;
|
||
let signalStrength = 0;
|
||
for (const net in NetworkService.networks) {
|
||
if (NetworkService.networks[net].connected) {
|
||
connected = true;
|
||
signalStrength = NetworkService.networks[net].signal;
|
||
break;
|
||
}
|
||
}
|
||
return connected ? NetworkService.signalIcon(signalStrength, true) : "wifi-off";
|
||
} catch (error) {
|
||
Logger.e("Wi-Fi", "Error getting icon:", error);
|
||
return "wifi-off";
|
||
}
|
||
}
|
||
text: {
|
||
try {
|
||
if (NetworkService.ethernetConnected) {
|
||
return "";
|
||
}
|
||
for (const net in NetworkService.networks) {
|
||
if (NetworkService.networks[net].connected) {
|
||
return net;
|
||
}
|
||
}
|
||
return "";
|
||
} catch (error) {
|
||
Logger.e("Wi-Fi", "Error getting ssid:", error);
|
||
return "error";
|
||
}
|
||
}
|
||
autoHide: false
|
||
forceOpen: !isBarVertical && root.displayMode === "alwaysShow"
|
||
forceClose: isBarVertical || root.displayMode === "alwaysHide" || text === ""
|
||
onClicked: {
|
||
var panel = PanelService.getPanel("networkPanel", screen);
|
||
panel?.toggle(this);
|
||
}
|
||
onRightClicked: {
|
||
PanelService.showContextMenu(contextMenu, pill, screen);
|
||
}
|
||
tooltipText: {
|
||
try {
|
||
if (NetworkService.ethernetConnected) {
|
||
const d = NetworkService.activeEthernetDetails || ({});
|
||
let base = "";
|
||
if (d.ifname && d.ifname.length > 0)
|
||
base = d.ifname;
|
||
else if (d.connectionName && d.connectionName.length > 0)
|
||
base = d.connectionName;
|
||
else if (NetworkService.activeEthernetIf && NetworkService.activeEthernetIf.length > 0)
|
||
base = NetworkService.activeEthernetIf;
|
||
else
|
||
base = I18n.tr("common.ethernet");
|
||
const speed = (d.speed && d.speed.length > 0) ? d.speed : "";
|
||
return speed ? (base + " — " + speed) : base;
|
||
}
|
||
// Wi‑Fi tooltip: SSID — link speed (if available)
|
||
if (pill.text !== "") {
|
||
const w = NetworkService.activeWifiDetails || ({});
|
||
const rate = (w.rateShort && w.rateShort.length > 0) ? w.rateShort : (w.rate || "");
|
||
return rate && rate.length > 0 ? (pill.text + " — " + rate) : pill.text;
|
||
}
|
||
} catch (e) {
|
||
// noop
|
||
}
|
||
return I18n.tr("common.wifi");
|
||
}
|
||
}
|
||
}
|