mirror of
https://github.com/noctalia-dev/noctalia-shell.git
synced 2026-05-11 17:08:27 +08:00
139 lines
4.4 KiB
QML
139 lines
4.4 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import Quickshell
|
|
import qs.Commons
|
|
import qs.Modules.Bar.Extras
|
|
import qs.Services.Networking
|
|
import qs.Services.UI
|
|
import qs.Widgets
|
|
|
|
Item {
|
|
id: root
|
|
|
|
property ShellScreen screen
|
|
|
|
property string widgetId: ""
|
|
property string section: ""
|
|
property int sectionWidgetIndex: -1
|
|
property int sectionWidgetsCount: 0
|
|
|
|
property var widgetMetadata: BarWidgetRegistry.widgetMetadata[widgetId]
|
|
property var widgetSettings: {
|
|
if (section && sectionWidgetIndex >= 0) {
|
|
var widgets = Settings.data.bar.widgets[section];
|
|
if (widgets && sectionWidgetIndex < widgets.length) {
|
|
return widgets[sectionWidgetIndex];
|
|
}
|
|
}
|
|
return {};
|
|
}
|
|
|
|
readonly property bool isBarVertical: Settings.data.bar.position === "left" || Settings.data.bar.position === "right"
|
|
readonly property string displayMode: widgetSettings.displayMode !== undefined ? widgetSettings.displayMode : widgetMetadata.displayMode
|
|
|
|
implicitWidth: pill.width
|
|
implicitHeight: pill.height
|
|
|
|
NPopupContextMenu {
|
|
id: contextMenu
|
|
|
|
model: {
|
|
const items = [];
|
|
const active = VPNService.activeConnections;
|
|
for (let i = 0; i < active.length; ++i) {
|
|
const conn = active[i];
|
|
items.push({
|
|
"label": I18n.tr("context-menu.disconnect-vpn", {
|
|
"name": conn.name
|
|
}),
|
|
"action": "disconnect:" + conn.uuid,
|
|
"icon": "shield-off"
|
|
});
|
|
}
|
|
const inactive = VPNService.inactiveConnections;
|
|
for (let i = 0; i < inactive.length; ++i) {
|
|
const conn = inactive[i];
|
|
items.push({
|
|
"label": I18n.tr("context-menu.connect-vpn", {
|
|
"name": conn.name
|
|
}),
|
|
"action": "connect:" + conn.uuid,
|
|
"icon": "shield-lock"
|
|
});
|
|
}
|
|
items.push({
|
|
"label": I18n.tr("context-menu.widget-settings"),
|
|
"action": "widget-settings",
|
|
"icon": "settings"
|
|
});
|
|
return items;
|
|
}
|
|
|
|
onTriggered: action => {
|
|
var popupMenuWindow = PanelService.getPopupMenuWindow(screen);
|
|
if (popupMenuWindow) {
|
|
popupMenuWindow.close();
|
|
}
|
|
if (!action) {
|
|
return;
|
|
}
|
|
if (action === "widget-settings") {
|
|
BarService.openWidgetSettings(screen, section, sectionWidgetIndex, widgetId, widgetSettings);
|
|
return;
|
|
}
|
|
if (action.startsWith("connect:")) {
|
|
const uuid = action.substring("connect:".length);
|
|
VPNService.connect(uuid);
|
|
return;
|
|
}
|
|
if (action.startsWith("disconnect:")) {
|
|
const uuid = action.substring("disconnect:".length);
|
|
VPNService.disconnect(uuid);
|
|
}
|
|
}
|
|
}
|
|
|
|
BarPill {
|
|
id: pill
|
|
|
|
screen: root.screen
|
|
density: Settings.data.bar.density
|
|
oppositeDirection: BarService.getPillDirection(root)
|
|
icon: VPNService.hasActiveConnection ? "shield-lock" : "shield"
|
|
text: {
|
|
if (VPNService.activeConnections.length > 0) {
|
|
return VPNService.activeConnections[0].name;
|
|
}
|
|
if (VPNService.connectingUuid) {
|
|
const pending = VPNService.connections[VPNService.connectingUuid];
|
|
if (pending) {
|
|
return pending.name;
|
|
}
|
|
}
|
|
return "";
|
|
}
|
|
suffix: {
|
|
if (VPNService.activeConnections.length > 1) {
|
|
return ` + ${VPNService.activeConnections.length - 1}`;
|
|
}
|
|
return "";
|
|
}
|
|
autoHide: false
|
|
forceOpen: !isBarVertical && root.displayMode === "alwaysShow"
|
|
forceClose: isBarVertical || root.displayMode === "alwaysHide" || !pill.text
|
|
onRightClicked: {
|
|
var popupMenuWindow = PanelService.getPopupMenuWindow(screen);
|
|
if (popupMenuWindow) {
|
|
popupMenuWindow.showContextMenu(contextMenu);
|
|
contextMenu.openAtItem(pill, screen);
|
|
}
|
|
}
|
|
tooltipText: {
|
|
if (pill.text !== "") {
|
|
return pill.text;
|
|
}
|
|
return I18n.tr("tooltips.manage-vpn");
|
|
}
|
|
}
|
|
}
|