mirror of
https://github.com/AvengeMedia/DankMaterialShell.git
synced 2026-06-15 23:55:21 -04:00
Compare commits
7 Commits
master
..
8d94117a69
| Author | SHA1 | Date | |
|---|---|---|---|
| 8d94117a69 | |||
| 92569d8b4d | |||
| fdee09b583 | |||
| b60af507d7 | |||
| 2cc12b70d2 | |||
| 2df1dfe0bd | |||
| abf084eea2 |
@@ -19,12 +19,7 @@ var (
|
||||
var colorCmd = &cobra.Command{
|
||||
Use: "color",
|
||||
Short: "Color utilities",
|
||||
Long: `Color utilities including picking colors from the screen.
|
||||
|
||||
This is the screen eyedropper CLI. To open the in-shell color modal, use:
|
||||
dms ipc call color-picker toggle
|
||||
|
||||
See: https://danklinux.com/docs/dankmaterialshell/keybinds-ipc`,
|
||||
Long: "Color utilities including picking colors from the screen",
|
||||
}
|
||||
|
||||
var colorPickCmd = &cobra.Command{
|
||||
@@ -34,9 +29,6 @@ var colorPickCmd = &cobra.Command{
|
||||
|
||||
Click on any pixel to capture its color, or press Escape to cancel.
|
||||
|
||||
This is the screen eyedropper CLI. To open the in-shell color modal, use:
|
||||
dms ipc call color-picker toggle
|
||||
|
||||
Output format flags (mutually exclusive, default: --hex):
|
||||
--hex - Hexadecimal (#RRGGBB)
|
||||
--rgb - RGB values (R G B)
|
||||
|
||||
@@ -77,15 +77,10 @@ var killCmd = &cobra.Command{
|
||||
}
|
||||
|
||||
var ipcCmd = &cobra.Command{
|
||||
Use: "ipc",
|
||||
Use: "ipc [target] [function] [args...]",
|
||||
Short: "Send IPC commands to running DMS shell",
|
||||
Long: `Send IPC commands to the running DMS shell.
|
||||
|
||||
dms ipc call <target> <function> [args...] invoke a command
|
||||
dms ipc list list all targets and functions
|
||||
|
||||
Full reference: https://danklinux.com/docs/dankmaterialshell/keybinds-ipc`,
|
||||
ValidArgsFunction: func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
|
||||
_ = findConfig(cmd, args)
|
||||
return getShellIPCCompletions(args, toComplete), cobra.ShellCompDirectiveNoFileComp
|
||||
},
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
@@ -93,17 +88,9 @@ Full reference: https://danklinux.com/docs/dankmaterialshell/keybinds-ipc`,
|
||||
},
|
||||
}
|
||||
|
||||
var ipcListCmd = &cobra.Command{
|
||||
Use: "list",
|
||||
Short: "List all IPC targets and functions",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
printIPCHelp()
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
ipcCmd.AddCommand(ipcListCmd)
|
||||
ipcCmd.SetHelpFunc(func(cmd *cobra.Command, args []string) {
|
||||
_ = findConfig(cmd, args)
|
||||
printIPCHelp()
|
||||
})
|
||||
}
|
||||
|
||||
+27
-44
@@ -601,30 +601,12 @@ func parseTargetsFromIPCShowOutput(output string) ipcTargets {
|
||||
return targets
|
||||
}
|
||||
|
||||
func buildQsIPCBaseArgs() ([]string, error) {
|
||||
cmdArgs := []string{"ipc"}
|
||||
switch pid, ok := getFirstDMSPID(); {
|
||||
case ok:
|
||||
cmdArgs = append(cmdArgs, "--pid", strconv.Itoa(pid))
|
||||
default:
|
||||
if err := findConfig(nil, nil); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if qsHasAnyDisplay() {
|
||||
cmdArgs = append(cmdArgs, "--any-display")
|
||||
}
|
||||
cmdArgs = append(cmdArgs, "-p", configPath)
|
||||
}
|
||||
return cmdArgs, nil
|
||||
}
|
||||
|
||||
func getShellIPCCompletions(args []string, _ string) []string {
|
||||
baseArgs, err := buildQsIPCBaseArgs()
|
||||
if err != nil {
|
||||
log.Debugf("Error building IPC args for completions: %v", err)
|
||||
return nil
|
||||
cmdArgs := []string{"ipc"}
|
||||
if qsHasAnyDisplay() {
|
||||
cmdArgs = append(cmdArgs, "--any-display")
|
||||
}
|
||||
cmdArgs := append(baseArgs, "show")
|
||||
cmdArgs = append(cmdArgs, "-p", configPath, "show")
|
||||
cmd := exec.Command("qs", cmdArgs...)
|
||||
var targets ipcTargets
|
||||
|
||||
@@ -641,7 +623,7 @@ func getShellIPCCompletions(args []string, _ string) []string {
|
||||
|
||||
if len(args) == 0 {
|
||||
targetNames := make([]string, 0)
|
||||
targetNames = append(targetNames, "call", "list")
|
||||
targetNames = append(targetNames, "call")
|
||||
for k := range targets {
|
||||
targetNames = append(targetNames, k)
|
||||
}
|
||||
@@ -714,11 +696,23 @@ func runShellIPCCommand(args []string) {
|
||||
args = append([]string{"call"}, args...)
|
||||
}
|
||||
|
||||
baseArgs, err := buildQsIPCBaseArgs()
|
||||
if err != nil {
|
||||
log.Fatalf("Error finding config: %v", err)
|
||||
cmdArgs := []string{"ipc"}
|
||||
|
||||
switch pid, ok := getFirstDMSPID(); {
|
||||
case ok:
|
||||
cmdArgs = append(cmdArgs, "--pid", strconv.Itoa(pid))
|
||||
default:
|
||||
if err := findConfig(nil, nil); err != nil {
|
||||
log.Fatalf("Error finding config: %v", err)
|
||||
}
|
||||
// ! TODO - remove check when QS 0.3 is released
|
||||
if qsHasAnyDisplay() {
|
||||
cmdArgs = append(cmdArgs, "--any-display")
|
||||
}
|
||||
cmdArgs = append(cmdArgs, "-p", configPath)
|
||||
}
|
||||
cmdArgs := append(baseArgs, args...)
|
||||
|
||||
cmdArgs = append(cmdArgs, args...)
|
||||
cmd := exec.Command("qs", cmdArgs...)
|
||||
cmd.Stdin = os.Stdin
|
||||
cmd.Stdout = os.Stdout
|
||||
@@ -730,20 +724,19 @@ func runShellIPCCommand(args []string) {
|
||||
}
|
||||
|
||||
func printIPCHelp() {
|
||||
fmt.Println("Usage: dms ipc call <target> <function> [args...]")
|
||||
fmt.Println("Usage: dms ipc <target> <function> [args...]")
|
||||
fmt.Println()
|
||||
|
||||
baseArgs, err := buildQsIPCBaseArgs()
|
||||
if err != nil {
|
||||
printIPCHelpFailure(err)
|
||||
return
|
||||
cmdArgs := []string{"ipc"}
|
||||
if qsHasAnyDisplay() {
|
||||
cmdArgs = append(cmdArgs, "--any-display")
|
||||
}
|
||||
cmdArgs := append(baseArgs, "show")
|
||||
cmdArgs = append(cmdArgs, "-p", configPath, "show")
|
||||
cmd := exec.Command("qs", cmdArgs...)
|
||||
|
||||
output, err := cmd.Output()
|
||||
if err != nil {
|
||||
printIPCHelpFailure(err)
|
||||
fmt.Println("Could not retrieve available IPC targets (is DMS running?)")
|
||||
return
|
||||
}
|
||||
|
||||
@@ -772,16 +765,6 @@ func printIPCHelp() {
|
||||
}
|
||||
}
|
||||
|
||||
func printIPCHelpFailure(err error) {
|
||||
fmt.Println("Could not retrieve IPC targets.")
|
||||
if err != nil {
|
||||
fmt.Printf(" %v\n", err)
|
||||
}
|
||||
fmt.Println()
|
||||
fmt.Println(" Full docs: https://danklinux.com/docs/dankmaterialshell/keybinds-ipc")
|
||||
fmt.Println(" Try: dms ipc call <target> <function>")
|
||||
}
|
||||
|
||||
// ensureFontCache rebuilds the fontconfig cache if user-configured fonts are missing while skipping defaults
|
||||
func ensureFontCache() {
|
||||
if _, err := exec.LookPath("fc-list"); err != nil {
|
||||
|
||||
+1
-21
@@ -6,18 +6,6 @@ DankMaterialShell provides comprehensive IPC (Inter-Process Communication) funct
|
||||
dms ipc call <target> <function> [parameters...]
|
||||
```
|
||||
|
||||
## Discovering IPC commands
|
||||
|
||||
List all available targets and functions while DMS is running:
|
||||
|
||||
```bash
|
||||
dms ipc list
|
||||
dms ipc # same
|
||||
dms ipc --help # same, plus usage text
|
||||
```
|
||||
|
||||
Live listing requires DMS to be running. If listing fails, use this document or the [Keybinds & IPC docs](https://danklinux.com/docs/dankmaterialshell/keybinds-ipc) as an offline reference.
|
||||
|
||||
## Target: `audio`
|
||||
|
||||
Audio system control and information.
|
||||
@@ -719,7 +707,7 @@ File browser controls for selecting wallpapers and profile images.
|
||||
- Both browsers support common image formats (jpg, jpeg, png, bmp, gif, webp)
|
||||
|
||||
### Target: `color-picker`
|
||||
In-shell color picker modal for theme and settings color selection.
|
||||
Color picker modal control.
|
||||
|
||||
**Functions:**
|
||||
- `open` - Show color picker modal
|
||||
@@ -730,14 +718,6 @@ In-shell color picker modal for theme and settings color selection.
|
||||
- `toggle` - Toggle color picker modal visibility
|
||||
- `toggleInstant` - Toggle color picker modal visibility without animation on hide
|
||||
|
||||
**Note:** This controls the in-shell modal. To pick a pixel from the screen via CLI, use `dms color pick` instead (see [Color Picker CLI](https://danklinux.com/docs/dankmaterialshell/cli-color-picker)).
|
||||
|
||||
**Examples:**
|
||||
```bash
|
||||
dms ipc call color-picker toggle
|
||||
dms ipc call color-picker openColor "#3f51b5"
|
||||
```
|
||||
|
||||
### Target: `hypr`
|
||||
Hyprland-specific controls including keybinds cheatsheet and workspace overview (Hyprland only).
|
||||
|
||||
|
||||
@@ -7,31 +7,29 @@ Item {
|
||||
property alias path: socket.path
|
||||
property alias parser: socket.parser
|
||||
property bool connected: false
|
||||
property bool linkUp: false
|
||||
|
||||
property int reconnectBaseMs: 400
|
||||
property int reconnectMaxMs: 15000
|
||||
|
||||
property int _reconnectAttempt: 0
|
||||
|
||||
signal connectionStateChanged
|
||||
signal connectionStateChanged()
|
||||
|
||||
onConnectedChanged: {
|
||||
socket.connected = connected;
|
||||
socket.connected = connected
|
||||
}
|
||||
|
||||
Socket {
|
||||
id: socket
|
||||
|
||||
onConnectionStateChanged: {
|
||||
root.linkUp = connected;
|
||||
root.connectionStateChanged();
|
||||
root.connectionStateChanged()
|
||||
if (connected) {
|
||||
root._reconnectAttempt = 0;
|
||||
return;
|
||||
root._reconnectAttempt = 0
|
||||
return
|
||||
}
|
||||
if (root.connected) {
|
||||
root._scheduleReconnect();
|
||||
root._scheduleReconnect()
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -41,24 +39,24 @@ Item {
|
||||
interval: 0
|
||||
repeat: false
|
||||
onTriggered: {
|
||||
socket.connected = false;
|
||||
Qt.callLater(() => socket.connected = true);
|
||||
socket.connected = false
|
||||
Qt.callLater(() => socket.connected = true)
|
||||
}
|
||||
}
|
||||
|
||||
function send(data) {
|
||||
const json = typeof data === "string" ? data : JSON.stringify(data);
|
||||
const message = json.endsWith("\n") ? json : json + "\n";
|
||||
socket.write(message);
|
||||
socket.flush();
|
||||
const json = typeof data === "string" ? data : JSON.stringify(data)
|
||||
const message = json.endsWith("\n") ? json : json + "\n"
|
||||
socket.write(message)
|
||||
socket.flush()
|
||||
}
|
||||
|
||||
function _scheduleReconnect() {
|
||||
const pow = Math.min(_reconnectAttempt, 10);
|
||||
const base = Math.min(reconnectBaseMs * Math.pow(2, pow), reconnectMaxMs);
|
||||
const jitter = Math.floor(Math.random() * Math.floor(base / 4));
|
||||
reconnectTimer.interval = base + jitter;
|
||||
reconnectTimer.restart();
|
||||
_reconnectAttempt++;
|
||||
const pow = Math.min(_reconnectAttempt, 10)
|
||||
const base = Math.min(reconnectBaseMs * Math.pow(2, pow), reconnectMaxMs)
|
||||
const jitter = Math.floor(Math.random() * Math.floor(base / 4))
|
||||
reconnectTimer.interval = base + jitter
|
||||
reconnectTimer.restart()
|
||||
_reconnectAttempt++
|
||||
}
|
||||
}
|
||||
|
||||
@@ -56,9 +56,6 @@ const DMS_ACTIONS = [
|
||||
{ id: "spawn dms ipc call dankdash wallpaper", label: "Wallpaper Browser" },
|
||||
{ id: "spawn dms ipc call file browse wallpaper", label: "File: Browse Wallpaper" },
|
||||
{ id: "spawn dms ipc call file browse profile", label: "File: Browse Profile" },
|
||||
{ id: "spawn dms ipc call color-picker toggle", label: "Color Picker: Toggle" },
|
||||
{ id: "spawn dms ipc call color-picker open", label: "Color Picker: Open" },
|
||||
{ id: "spawn dms ipc call color-picker close", label: "Color Picker: Close" },
|
||||
{ id: "spawn dms ipc call keybinds toggle niri", label: "Keybinds Cheatsheet: Toggle", compositor: "niri" },
|
||||
{ id: "spawn dms ipc call keybinds open niri", label: "Keybinds Cheatsheet: Open", compositor: "niri" },
|
||||
{ id: "spawn dms ipc call keybinds close", label: "Keybinds Cheatsheet: Close" },
|
||||
|
||||
@@ -108,7 +108,6 @@ Singleton {
|
||||
}
|
||||
|
||||
property bool clipboardEnterToPaste: false
|
||||
property var clipboardVisibleEntryActions: ["pin", "edit", "delete"]
|
||||
|
||||
property var launcherPluginVisibility: ({})
|
||||
|
||||
@@ -182,7 +181,6 @@ Singleton {
|
||||
|
||||
property int firstDayOfWeek: -1
|
||||
property bool showWeekNumber: false
|
||||
property string calendarBackend: "auto"
|
||||
property bool use24HourClock: true
|
||||
property bool showSeconds: false
|
||||
property bool padHours12Hour: false
|
||||
@@ -398,7 +396,6 @@ Singleton {
|
||||
property bool audioVisualizerEnabled: true
|
||||
property string audioScrollMode: "volume"
|
||||
property int audioWheelScrollAmount: 5
|
||||
property bool audioDeviceScrollVolumeEnabled: false
|
||||
property bool clockCompactMode: false
|
||||
property int focusedWindowSize: 1
|
||||
property bool focusedWindowCompactMode: false
|
||||
@@ -406,9 +403,6 @@ Singleton {
|
||||
property int barMaxVisibleApps: 0
|
||||
property int barMaxVisibleRunningApps: 0
|
||||
property bool barShowOverflowBadge: true
|
||||
property bool trayAutoOverflow: true
|
||||
property bool trayPopupSingleLine: true
|
||||
property int trayMaxVisibleItems: 0
|
||||
property bool appsDockHideIndicators: false
|
||||
property bool appsDockColorizeActive: false
|
||||
property string appsDockActiveColorMode: "primary"
|
||||
@@ -524,39 +518,13 @@ Singleton {
|
||||
property real notificationSummaryFontSize: Spec.SPEC.notificationSummaryFontSize.def
|
||||
property real notificationBodyFontSize: Spec.SPEC.notificationBodyFontSize.def
|
||||
property bool notepadShowLineNumbers: false
|
||||
property bool notepadAutoSave: false
|
||||
property string notepadSlideoutSide: "right"
|
||||
property string notepadDefaultMode: "slideout"
|
||||
property real notepadTransparencyOverride: -1
|
||||
property real notepadLastCustomTransparency: 0.7
|
||||
property bool notepadUseCompositorGap: false
|
||||
property int notepadEdgeGap: 0
|
||||
|
||||
// Compositor layout gap when enabled and available, else the manual value.
|
||||
readonly property int notepadEffectiveEdgeGap: {
|
||||
if (notepadUseCompositorGap) {
|
||||
var g = -1;
|
||||
if (CompositorService.isNiri)
|
||||
g = niriLayoutGapsOverride;
|
||||
else if (CompositorService.isHyprland)
|
||||
g = hyprlandLayoutGapsOverride;
|
||||
else if (CompositorService.isMango)
|
||||
g = mangoLayoutGapsOverride;
|
||||
if (g >= 0)
|
||||
return g;
|
||||
}
|
||||
return Math.max(0, notepadEdgeGap);
|
||||
}
|
||||
|
||||
onNotepadUseMonospaceChanged: saveSettings()
|
||||
onNotepadFontFamilyChanged: saveSettings()
|
||||
onNotepadFontSizeChanged: saveSettings()
|
||||
onNotepadShowLineNumbersChanged: saveSettings()
|
||||
onNotepadAutoSaveChanged: saveSettings()
|
||||
onNotepadSlideoutSideChanged: saveSettings()
|
||||
onNotepadDefaultModeChanged: saveSettings()
|
||||
onNotepadUseCompositorGapChanged: saveSettings()
|
||||
onNotepadEdgeGapChanged: saveSettings()
|
||||
// onCenteringModeChanged: saveSettings()
|
||||
onNotepadTransparencyOverrideChanged: {
|
||||
if (notepadTransparencyOverride > 0) {
|
||||
@@ -1682,15 +1650,6 @@ Singleton {
|
||||
};
|
||||
}
|
||||
|
||||
function effectiveBarConfigForRender(config, usesFrameBarChrome) {
|
||||
if (!config || !connectedFrameModeActive || usesFrameBarChrome)
|
||||
return config;
|
||||
const backup = connectedFrameBarStyleBackups[config.id];
|
||||
if (!backup)
|
||||
return config;
|
||||
return Object.assign({}, config, backup);
|
||||
}
|
||||
|
||||
// Single entry point for connected-mode settings state.
|
||||
// !active → restore backups
|
||||
function _reconcileConnectedFrameBarStyles() {
|
||||
|
||||
@@ -37,7 +37,6 @@ var SPEC = {
|
||||
|
||||
firstDayOfWeek: { def: -1 },
|
||||
showWeekNumber: { def: false },
|
||||
calendarBackend: { def: "auto" },
|
||||
use24HourClock: { def: true },
|
||||
showSeconds: { def: false },
|
||||
padHours12Hour: { def: false },
|
||||
@@ -157,7 +156,6 @@ var SPEC = {
|
||||
audioVisualizerEnabled: { def: true },
|
||||
audioScrollMode: { def: "volume" },
|
||||
audioWheelScrollAmount: { def: 5 },
|
||||
audioDeviceScrollVolumeEnabled: { def: false },
|
||||
clockCompactMode: { def: false },
|
||||
focusedWindowCompactMode: { def: false },
|
||||
focusedWindowSize: { def: 1 },
|
||||
@@ -165,9 +163,6 @@ var SPEC = {
|
||||
barMaxVisibleApps: { def: 0 },
|
||||
barMaxVisibleRunningApps: { def: 0 },
|
||||
barShowOverflowBadge: { def: true },
|
||||
trayAutoOverflow: { def: true },
|
||||
trayPopupSingleLine: { def: true },
|
||||
trayMaxVisibleItems: { def: 0 },
|
||||
appsDockHideIndicators: { def: false },
|
||||
appsDockColorizeActive: { def: false },
|
||||
appsDockActiveColorMode: { def: "primary" },
|
||||
@@ -268,13 +263,8 @@ var SPEC = {
|
||||
notificationSummaryFontSize: { def: 0 },
|
||||
notificationBodyFontSize: { def: 0 },
|
||||
notepadShowLineNumbers: { def: false },
|
||||
notepadAutoSave: { def: false },
|
||||
notepadSlideoutSide: { def: "right" },
|
||||
notepadDefaultMode: { def: "slideout" },
|
||||
notepadTransparencyOverride: { def: -1 },
|
||||
notepadLastCustomTransparency: { def: 0.7 },
|
||||
notepadUseCompositorGap: { def: false },
|
||||
notepadEdgeGap: { def: 0 },
|
||||
|
||||
soundsEnabled: { def: true },
|
||||
useSystemSoundTheme: { def: false },
|
||||
@@ -582,7 +572,6 @@ var SPEC = {
|
||||
|
||||
builtInPluginSettings: { def: {} },
|
||||
clipboardEnterToPaste: { def: false },
|
||||
clipboardVisibleEntryActions: { def: ["pin", "edit", "delete"] },
|
||||
|
||||
launcherPluginVisibility: { def: {} },
|
||||
launcherPluginOrder: { def: [] },
|
||||
|
||||
+19
-31
@@ -64,15 +64,27 @@ Item {
|
||||
}
|
||||
}
|
||||
|
||||
property bool wallpaperSurfacesLoaded: true
|
||||
|
||||
Loader {
|
||||
id: blurredWallpaperBackgroundLoader
|
||||
active: SettingsData.blurredWallpaperLayer && CompositorService.isNiri
|
||||
active: root.wallpaperSurfacesLoaded && SettingsData.blurredWallpaperLayer && CompositorService.isNiri
|
||||
asynchronous: false
|
||||
|
||||
sourceComponent: BlurredWallpaperBackground {}
|
||||
}
|
||||
|
||||
WallpaperBackground {}
|
||||
DeferredAction {
|
||||
id: wallpaperSurfaceReloadAction
|
||||
onTriggered: root.wallpaperSurfacesLoaded = true
|
||||
}
|
||||
|
||||
Loader {
|
||||
id: wallpaperBackgroundLoader
|
||||
active: root.wallpaperSurfacesLoaded
|
||||
asynchronous: false
|
||||
sourceComponent: WallpaperBackground {}
|
||||
}
|
||||
|
||||
DesktopWidgetLayer {}
|
||||
|
||||
@@ -386,6 +398,11 @@ Item {
|
||||
frameSurfaceReloadAction.schedule();
|
||||
}
|
||||
|
||||
if (root.wallpaperSurfacesLoaded) {
|
||||
root.wallpaperSurfacesLoaded = false;
|
||||
wallpaperSurfaceReloadAction.schedule();
|
||||
}
|
||||
|
||||
root.dockEnabled = false;
|
||||
Qt.callLater(() => {
|
||||
root.dockEnabled = true;
|
||||
@@ -1093,22 +1110,11 @@ Item {
|
||||
slideoutWidth: 480
|
||||
expandable: true
|
||||
expandedWidthValue: 960
|
||||
edgeGap: SettingsData.notepadEffectiveEdgeGap
|
||||
slideEdge: SettingsData.notepadSlideoutSide
|
||||
|
||||
onIsVisibleChanged: {
|
||||
if (isVisible)
|
||||
PopoutService.notepadPopout?.hide();
|
||||
}
|
||||
|
||||
content: Component {
|
||||
Notepad {
|
||||
slideout: notepadSlideout
|
||||
onHideRequested: notepadSlideout.hide()
|
||||
onPopoutRequested: {
|
||||
notepadSlideout.hide();
|
||||
PopoutService.openNotepadPopout();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1125,24 +1131,6 @@ Item {
|
||||
Component.onCompleted: PopoutService.notepadSlideouts = instances
|
||||
}
|
||||
|
||||
LazyLoader {
|
||||
id: notepadPopoutLoader
|
||||
active: false
|
||||
|
||||
Component.onCompleted: {
|
||||
PopoutService.notepadPopoutLoader = notepadPopoutLoader;
|
||||
}
|
||||
|
||||
onActiveChanged: {
|
||||
if (active && item) {
|
||||
PopoutService.notepadPopout = item;
|
||||
PopoutService._onNotepadPopoutLoaded();
|
||||
}
|
||||
}
|
||||
|
||||
NotepadPopoutWindow {}
|
||||
}
|
||||
|
||||
LazyLoader {
|
||||
id: powerMenuModalLoader
|
||||
|
||||
|
||||
@@ -373,10 +373,6 @@ Item {
|
||||
}
|
||||
|
||||
function open(): string {
|
||||
if (SettingsData.notepadDefaultMode === "popout") {
|
||||
PopoutService.openNotepadPopout();
|
||||
return "NOTEPAD_OPEN_SUCCESS";
|
||||
}
|
||||
var instance = getActiveNotepadInstance();
|
||||
if (instance) {
|
||||
instance.show();
|
||||
@@ -386,10 +382,6 @@ Item {
|
||||
}
|
||||
|
||||
function close(): string {
|
||||
if (SettingsData.notepadDefaultMode === "popout") {
|
||||
PopoutService.notepadPopout?.hide();
|
||||
return "NOTEPAD_CLOSE_SUCCESS";
|
||||
}
|
||||
var instance = getActiveNotepadInstance();
|
||||
if (instance) {
|
||||
instance.hide();
|
||||
@@ -399,10 +391,6 @@ Item {
|
||||
}
|
||||
|
||||
function toggle(): string {
|
||||
if (SettingsData.notepadDefaultMode === "popout") {
|
||||
PopoutService.toggleNotepadPopout();
|
||||
return "NOTEPAD_TOGGLE_SUCCESS";
|
||||
}
|
||||
var instance = getActiveNotepadInstance();
|
||||
if (instance) {
|
||||
instance.toggle();
|
||||
@@ -956,7 +944,7 @@ Item {
|
||||
|
||||
function tabs(): string {
|
||||
if (!PopoutService.settingsModal)
|
||||
return "wallpaper\ntheme\ntypography\ntime_weather\nsounds\ndankbar\ndankbar_settings\ndankbar_appearance\ndankbar_widgets\nframe\nworkspaces\ncompositor\nmedia_player\nnotifications\nosd\nrunning_apps\nupdater\ndock\nlauncher\nkeybinds\ndisplays\nnetwork\nnetwork_status\nnetwork_ethernet\nnetwork_wifi\nnetwork_vpn\nprinters\nlock_screen\npower_sleep\nplugins\nabout";
|
||||
return "wallpaper\ntheme\ntypography\ntime_weather\nsounds\ndankbar\ndankbar_settings\ndankbar_appearance\ndankbar_widgets\nframe\nworkspaces\ncompositor\nmedia_player\nnotifications\nosd\nrunning_apps\nupdater\ndock\nlauncher\nkeybinds\ndisplays\nnetwork\nprinters\nlock_screen\npower_sleep\nplugins\nabout";
|
||||
var modal = PopoutService.settingsModal;
|
||||
var ids = [];
|
||||
var structure = modal.sidebar?.categoryStructure ?? [];
|
||||
|
||||
@@ -7,6 +7,7 @@ Item {
|
||||
id: clipboardContent
|
||||
|
||||
required property var modal
|
||||
required property var clearConfirmDialog
|
||||
|
||||
property alias searchField: searchField
|
||||
property alias clipboardListView: clipboardListView
|
||||
@@ -32,7 +33,14 @@ Item {
|
||||
pinnedCount: modal.pinnedCount
|
||||
onKeyboardHintsToggled: modal.showKeyboardHints = !modal.showKeyboardHints
|
||||
onTabChanged: tabName => modal.activeTab = tabName
|
||||
onClearAllClicked: modal.confirmClearAll()
|
||||
onClearAllClicked: {
|
||||
const hasPinned = modal.pinnedCount > 0;
|
||||
const message = hasPinned ? I18n.tr("This will delete all unpinned entries. %1 pinned entries will be kept.").arg(modal.pinnedCount) : I18n.tr("This will permanently delete all clipboard history.");
|
||||
clearConfirmDialog.show(I18n.tr("Clear History?"), message, function () {
|
||||
modal.clearAll();
|
||||
modal.hide();
|
||||
}, function () {});
|
||||
}
|
||||
onCloseClicked: modal.hide()
|
||||
}
|
||||
|
||||
|
||||
@@ -22,14 +22,7 @@ Rectangle {
|
||||
readonly property string entryType: modal ? modal.getEntryType(entry) : "text"
|
||||
readonly property string entryPreview: modal ? modal.getEntryPreview(entry) : ""
|
||||
readonly property var pinnedDuplicateEntry: !entry.pinned ? ClipboardService.getPinnedEntryByHash(entry.hash) : null
|
||||
readonly property bool hasPinnedDuplicate: pinnedDuplicateEntry !== null
|
||||
readonly property bool effectivePinned: entry.pinned || hasPinnedDuplicate
|
||||
readonly property var visibleEntryActions: SettingsData.clipboardVisibleEntryActions || ["pin", "edit", "delete"]
|
||||
readonly property bool showPinAction: visibleEntryActions.includes("pin")
|
||||
readonly property bool showEditAction: visibleEntryActions.includes("edit")
|
||||
readonly property bool showDeleteAction: visibleEntryActions.includes("delete")
|
||||
readonly property bool showPinnedIndicator: hasPinnedDuplicate && !showPinAction
|
||||
readonly property bool showAnyAction: showPinAction || showEditAction || showDeleteAction || showPinnedIndicator
|
||||
readonly property bool effectivePinned: entry.pinned || pinnedDuplicateEntry !== null
|
||||
|
||||
radius: Theme.cornerRadius
|
||||
color: {
|
||||
@@ -70,28 +63,12 @@ Rectangle {
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingXS
|
||||
visible: root.showAnyAction
|
||||
|
||||
Item {
|
||||
width: 40
|
||||
height: 40
|
||||
visible: root.showPinnedIndicator
|
||||
|
||||
// Status indicator only; the Pin action remains hidden.
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: "push_pin"
|
||||
size: Theme.iconSize - 6
|
||||
color: Theme.primary
|
||||
}
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
iconName: "push_pin"
|
||||
iconSize: Theme.iconSize - 6
|
||||
iconColor: (entry.pinned || hasPinnedDuplicate) ? Theme.primary : Theme.surfaceText
|
||||
backgroundColor: (entry.pinned || hasPinnedDuplicate) ? Theme.primarySelected : "transparent"
|
||||
visible: root.showPinAction
|
||||
iconColor: effectivePinned ? Theme.primary : Theme.surfaceText
|
||||
backgroundColor: effectivePinned ? Theme.primarySelected : "transparent"
|
||||
onClicked: {
|
||||
if (entry.pinned) {
|
||||
unpinRequested(entry);
|
||||
@@ -109,7 +86,6 @@ Rectangle {
|
||||
iconName: "edit"
|
||||
iconSize: Theme.iconSize - 6
|
||||
iconColor: Theme.surfaceText
|
||||
visible: root.showEditAction
|
||||
|
||||
onClicked: {
|
||||
if (entryType === "image") {
|
||||
@@ -123,7 +99,6 @@ Rectangle {
|
||||
iconName: "close"
|
||||
iconSize: Theme.iconSize - 6
|
||||
iconColor: Theme.surfaceText
|
||||
visible: root.showDeleteAction
|
||||
onClicked: deleteRequested()
|
||||
}
|
||||
}
|
||||
@@ -131,8 +106,8 @@ Rectangle {
|
||||
Item {
|
||||
anchors.left: indexBadge.right
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.right: root.showAnyAction ? actionButtons.left : parent.right
|
||||
anchors.rightMargin: root.showAnyAction ? Theme.spacingM : Theme.spacingS
|
||||
anchors.right: actionButtons.left
|
||||
anchors.rightMargin: Theme.spacingM
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
// height: contentColumn.implicitHeight
|
||||
height: ClipboardConstants.itemHeight
|
||||
@@ -193,8 +168,8 @@ Rectangle {
|
||||
MouseArea {
|
||||
id: mouseArea
|
||||
anchors.left: parent.left
|
||||
anchors.right: root.showAnyAction ? actionButtons.left : parent.right
|
||||
anchors.rightMargin: root.showAnyAction ? Theme.spacingS : 0
|
||||
anchors.right: actionButtons.left
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.top: parent.top
|
||||
anchors.bottom: parent.bottom
|
||||
hoverEnabled: true
|
||||
|
||||
@@ -82,15 +82,6 @@ FocusScope {
|
||||
ClipboardService.clearAll();
|
||||
}
|
||||
|
||||
function confirmClearAll() {
|
||||
const hasPinned = pinnedCount > 0;
|
||||
const message = hasPinned ? I18n.tr("This will delete all unpinned entries. %1 pinned entries will be kept.").arg(pinnedCount) : I18n.tr("This will permanently delete all clipboard history.");
|
||||
clearConfirmDialog.show(I18n.tr("Clear History?"), message, function () {
|
||||
clearAll();
|
||||
hide();
|
||||
}, function () {});
|
||||
}
|
||||
|
||||
function getEntryPreview(entry) {
|
||||
return ClipboardService.getEntryPreview(entry);
|
||||
}
|
||||
@@ -144,6 +135,7 @@ FocusScope {
|
||||
id: historyContent
|
||||
anchors.fill: parent
|
||||
modal: root
|
||||
clearConfirmDialog: root.clearConfirmDialog
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -77,35 +77,22 @@ DankModal {
|
||||
id: clearConfirmDialog
|
||||
confirmButtonText: I18n.tr("Clear All")
|
||||
confirmButtonColor: Theme.primary
|
||||
onShouldBeVisibleChanged: {
|
||||
if (shouldBeVisible) {
|
||||
onVisibleChanged: {
|
||||
if (visible) {
|
||||
clipboardHistoryModal.shouldHaveFocus = false;
|
||||
selectedButton = 0;
|
||||
keyboardNavigation = true;
|
||||
return;
|
||||
}
|
||||
Qt.callLater(function () {
|
||||
if (!clipboardHistoryModal.shouldBeVisible) {
|
||||
return;
|
||||
}
|
||||
clipboardHistoryModal.shouldHaveFocus = Qt.binding(() => clipboardHistoryModal.shouldBeVisible);
|
||||
clipboardHistoryModal.shouldHaveFocus = true;
|
||||
clipboardHistoryModal.modalFocusScope.forceActiveFocus();
|
||||
if (clipboardHistoryModal.contentLoader.item?.searchField) {
|
||||
clipboardHistoryModal.contentLoader.item.searchField.forceActiveFocus();
|
||||
}
|
||||
});
|
||||
}
|
||||
Connections {
|
||||
target: clearConfirmDialog.modalFocusScope.Keys
|
||||
function onPressed(event) {
|
||||
if (!clearConfirmDialog.shouldBeVisible || event.key !== Qt.Key_Backtab) {
|
||||
return;
|
||||
}
|
||||
clearConfirmDialog.selectedButton = clearConfirmDialog.selectedButton === -1 ? 1 : (clearConfirmDialog.selectedButton - 1 + 2) % 2;
|
||||
clearConfirmDialog.keyboardNavigation = true;
|
||||
event.accepted = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
content: Component {
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
|
||||
import QtQuick
|
||||
import Quickshell.Wayland
|
||||
import qs.Common
|
||||
import qs.Modals.Clipboard
|
||||
import qs.Modals.Common
|
||||
@@ -96,35 +95,6 @@ DankPopout {
|
||||
id: clearConfirmDialog
|
||||
confirmButtonText: I18n.tr("Clear All")
|
||||
confirmButtonColor: Theme.primary
|
||||
onShouldBeVisibleChanged: {
|
||||
if (shouldBeVisible) {
|
||||
root.customKeyboardFocus = WlrKeyboardFocus.None;
|
||||
selectedButton = 0;
|
||||
keyboardNavigation = true;
|
||||
return;
|
||||
}
|
||||
root.customKeyboardFocus = null;
|
||||
Qt.callLater(function () {
|
||||
if (!root.shouldBeVisible || !root.contentLoader.item) {
|
||||
return;
|
||||
}
|
||||
root.contentLoader.item.forceActiveFocus();
|
||||
if (root.contentLoader.item.searchField) {
|
||||
root.contentLoader.item.searchField.forceActiveFocus();
|
||||
}
|
||||
});
|
||||
}
|
||||
Connections {
|
||||
target: clearConfirmDialog.modalFocusScope.Keys
|
||||
function onPressed(event) {
|
||||
if (!clearConfirmDialog.shouldBeVisible || event.key !== Qt.Key_Backtab) {
|
||||
return;
|
||||
}
|
||||
clearConfirmDialog.selectedButton = clearConfirmDialog.selectedButton === -1 ? 1 : (clearConfirmDialog.selectedButton - 1 + 2) % 2;
|
||||
clearConfirmDialog.keyboardNavigation = true;
|
||||
event.accepted = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
content: Component {
|
||||
|
||||
@@ -125,6 +125,8 @@ QtObject {
|
||||
if (!ClipboardService.keyboardNavigationActive) {
|
||||
ClipboardService.keyboardNavigationActive = true;
|
||||
ClipboardService.selectedIndex = 0;
|
||||
} else if (ClipboardService.selectedIndex === 0) {
|
||||
ClipboardService.keyboardNavigationActive = false;
|
||||
} else {
|
||||
selectPrevious();
|
||||
}
|
||||
@@ -153,6 +155,8 @@ QtObject {
|
||||
if (!ClipboardService.keyboardNavigationActive) {
|
||||
ClipboardService.keyboardNavigationActive = true;
|
||||
ClipboardService.selectedIndex = 0;
|
||||
} else if (ClipboardService.selectedIndex === 0) {
|
||||
ClipboardService.keyboardNavigationActive = false;
|
||||
} else {
|
||||
selectPrevious();
|
||||
}
|
||||
@@ -180,7 +184,8 @@ QtObject {
|
||||
if (event.modifiers & Qt.ShiftModifier) {
|
||||
switch (event.key) {
|
||||
case Qt.Key_Delete:
|
||||
modal.confirmClearAll();
|
||||
modal.clearAll();
|
||||
modal.hide();
|
||||
event.accepted = true;
|
||||
return;
|
||||
case Qt.Key_Return:
|
||||
|
||||
@@ -201,21 +201,6 @@ FocusScope {
|
||||
keyboardSelectionRequested = true;
|
||||
}
|
||||
|
||||
function activateFile(path, name, isDir) {
|
||||
if (isDir) {
|
||||
navigateTo(path);
|
||||
return;
|
||||
}
|
||||
if (saveMode) {
|
||||
saveRow.fileName = name;
|
||||
pendingFilePath = path;
|
||||
showOverwriteConfirmation = true;
|
||||
} else {
|
||||
fileSelected(path);
|
||||
closeRequested();
|
||||
}
|
||||
}
|
||||
|
||||
function handleSaveFile(filePath) {
|
||||
var normalizedPath = filePath;
|
||||
if (!normalizedPath.startsWith("file://")) {
|
||||
@@ -667,7 +652,6 @@ FocusScope {
|
||||
|
||||
Row {
|
||||
anchors.fill: parent
|
||||
anchors.bottomMargin: root.saveMode ? 40 + Theme.spacingL * 2 : 0
|
||||
spacing: 0
|
||||
|
||||
Row {
|
||||
@@ -772,7 +756,12 @@ FocusScope {
|
||||
onItemClicked: (index, path, name, isDir) => {
|
||||
selectedIndex = index;
|
||||
setSelectedFileData(path, name, isDir);
|
||||
root.activateFile(path, name, isDir);
|
||||
if (isDir) {
|
||||
navigateTo(path);
|
||||
} else {
|
||||
fileSelected(path);
|
||||
root.closeRequested();
|
||||
}
|
||||
}
|
||||
onItemSelected: (index, path, name, isDir) => {
|
||||
setSelectedFileData(path, name, isDir);
|
||||
@@ -787,7 +776,12 @@ FocusScope {
|
||||
root.keyboardSelectionRequested = false;
|
||||
selectedIndex = index;
|
||||
setSelectedFileData(filePath, fileName, fileIsDir);
|
||||
root.activateFile(filePath, fileName, fileIsDir);
|
||||
if (fileIsDir) {
|
||||
navigateTo(filePath);
|
||||
} else {
|
||||
fileSelected(filePath);
|
||||
root.closeRequested();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -823,7 +817,12 @@ FocusScope {
|
||||
onItemClicked: (index, path, name, isDir) => {
|
||||
selectedIndex = index;
|
||||
setSelectedFileData(path, name, isDir);
|
||||
root.activateFile(path, name, isDir);
|
||||
if (isDir) {
|
||||
navigateTo(path);
|
||||
} else {
|
||||
fileSelected(path);
|
||||
root.closeRequested();
|
||||
}
|
||||
}
|
||||
onItemSelected: (index, path, name, isDir) => {
|
||||
setSelectedFileData(path, name, isDir);
|
||||
@@ -838,7 +837,12 @@ FocusScope {
|
||||
root.keyboardSelectionRequested = false;
|
||||
selectedIndex = index;
|
||||
setSelectedFileData(filePath, fileName, fileIsDir);
|
||||
root.activateFile(filePath, fileName, fileIsDir);
|
||||
if (fileIsDir) {
|
||||
navigateTo(filePath);
|
||||
} else {
|
||||
fileSelected(filePath);
|
||||
root.closeRequested();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -851,7 +855,6 @@ FocusScope {
|
||||
}
|
||||
|
||||
FileBrowserSaveRow {
|
||||
id: saveRow
|
||||
anchors.bottom: parent.bottom
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
@@ -910,21 +913,21 @@ FocusScope {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
FileBrowserOverwriteDialog {
|
||||
anchors.fill: parent
|
||||
showDialog: showOverwriteConfirmation
|
||||
pendingFilePath: root.pendingFilePath
|
||||
onConfirmed: filePath => {
|
||||
showOverwriteConfirmation = false;
|
||||
fileSelected(filePath);
|
||||
pendingFilePath = "";
|
||||
Qt.callLater(() => root.closeRequested());
|
||||
}
|
||||
onCancelled: {
|
||||
showOverwriteConfirmation = false;
|
||||
pendingFilePath = "";
|
||||
FileBrowserOverwriteDialog {
|
||||
anchors.fill: parent
|
||||
showDialog: showOverwriteConfirmation
|
||||
pendingFilePath: root.pendingFilePath
|
||||
onConfirmed: filePath => {
|
||||
showOverwriteConfirmation = false;
|
||||
fileSelected(filePath);
|
||||
pendingFilePath = "";
|
||||
Qt.callLater(() => root.closeRequested());
|
||||
}
|
||||
onCancelled: {
|
||||
showOverwriteConfirmation = false;
|
||||
pendingFilePath = "";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -74,7 +74,7 @@ Item {
|
||||
width: 80
|
||||
height: 36
|
||||
radius: Theme.cornerRadius
|
||||
color: cancelArea.containsMouse ? Qt.lighter(Theme.surfaceVariant, 1.2) : Theme.surfaceVariant
|
||||
color: cancelArea.containsMouse ? Theme.surfaceVariantHover : Theme.surfaceVariant
|
||||
border.color: Theme.outline
|
||||
border.width: 1
|
||||
|
||||
|
||||
@@ -8,7 +8,6 @@ Row {
|
||||
property bool saveMode: false
|
||||
property string defaultFileName: ""
|
||||
property string currentPath: ""
|
||||
property alias fileName: fileNameInput.text
|
||||
|
||||
signal saveRequested(string filePath)
|
||||
|
||||
|
||||
@@ -11,7 +11,6 @@ DankModal {
|
||||
|
||||
layerNamespace: "dms:power-menu"
|
||||
keepPopoutsOpen: true
|
||||
useOverlayLayer: true
|
||||
|
||||
property int selectedIndex: 0
|
||||
property int selectedRow: 0
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
import QtQuick
|
||||
import qs.Common
|
||||
import qs.Modules.Settings
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
|
||||
FocusScope {
|
||||
@@ -233,52 +232,7 @@ FocusScope {
|
||||
visible: active
|
||||
focus: active
|
||||
|
||||
sourceComponent: NetworkStatusTab {}
|
||||
|
||||
onActiveChanged: {
|
||||
if (active && item)
|
||||
Qt.callLater(() => item.forceActiveFocus());
|
||||
}
|
||||
}
|
||||
|
||||
Loader {
|
||||
id: networkEthernetLoader
|
||||
anchors.fill: parent
|
||||
active: root.currentIndex === 39
|
||||
visible: active
|
||||
focus: active
|
||||
|
||||
sourceComponent: NetworkEthernetTab {}
|
||||
|
||||
onActiveChanged: {
|
||||
if (active && item)
|
||||
Qt.callLater(() => item.forceActiveFocus());
|
||||
}
|
||||
}
|
||||
|
||||
Loader {
|
||||
id: networkWifiLoader
|
||||
anchors.fill: parent
|
||||
active: root.currentIndex === 40
|
||||
visible: active
|
||||
focus: active
|
||||
|
||||
sourceComponent: NetworkWifiTab {}
|
||||
|
||||
onActiveChanged: {
|
||||
if (active && item)
|
||||
Qt.callLater(() => item.forceActiveFocus());
|
||||
}
|
||||
}
|
||||
|
||||
Loader {
|
||||
id: networkVpnLoader
|
||||
anchors.fill: parent
|
||||
active: root.currentIndex === 41
|
||||
visible: active
|
||||
focus: active
|
||||
|
||||
sourceComponent: NetworkVpnTab {}
|
||||
sourceComponent: NetworkTab {}
|
||||
|
||||
onActiveChanged: {
|
||||
if (active && item)
|
||||
|
||||
@@ -53,21 +53,20 @@ FloatingWindow {
|
||||
visible = !visible;
|
||||
}
|
||||
|
||||
function setTabIndex(tabIndex: int) {
|
||||
if (tabIndex < 0)
|
||||
return;
|
||||
currentTabIndex = tabIndex;
|
||||
sidebar.autoExpandForTab(tabIndex);
|
||||
}
|
||||
|
||||
function showWithTab(tabIndex: int) {
|
||||
setTabIndex(tabIndex);
|
||||
if (tabIndex >= 0) {
|
||||
currentTabIndex = tabIndex;
|
||||
sidebar.autoExpandForTab(tabIndex);
|
||||
}
|
||||
visible = true;
|
||||
}
|
||||
|
||||
function showWithTabName(tabName: string) {
|
||||
var idx = sidebar.resolveTabIndex(tabName);
|
||||
setTabIndex(idx);
|
||||
if (idx >= 0) {
|
||||
currentTabIndex = idx;
|
||||
sidebar.autoExpandForTab(idx);
|
||||
}
|
||||
visible = true;
|
||||
}
|
||||
|
||||
|
||||
@@ -105,8 +105,8 @@ Rectangle {
|
||||
},
|
||||
{
|
||||
"id": "compositor_layout",
|
||||
"text": CompositorService.isNiri ? "Niri" : (CompositorService.isHyprland ? "Hyprland" : "MangoWC"),
|
||||
"icon": "layers",
|
||||
"text": CompositorService.isNiri ? "niri" : (CompositorService.isHyprland ? "Hyprland" : "MangoWC"),
|
||||
"icon": "crop_square",
|
||||
"tabIndex": 37,
|
||||
"layoutCapable": true
|
||||
}
|
||||
@@ -117,18 +117,18 @@ Rectangle {
|
||||
"text": I18n.tr("Dank Bar"),
|
||||
"icon": "toolbar",
|
||||
"children": [
|
||||
{
|
||||
"id": "dankbar_appearance",
|
||||
"text": I18n.tr("Appearance"),
|
||||
"icon": "palette",
|
||||
"tabIndex": 6
|
||||
},
|
||||
{
|
||||
"id": "dankbar_settings",
|
||||
"text": I18n.tr("Settings"),
|
||||
"icon": "tune",
|
||||
"tabIndex": 3
|
||||
},
|
||||
{
|
||||
"id": "dankbar_appearance",
|
||||
"text": I18n.tr("Appearance"),
|
||||
"icon": "palette",
|
||||
"tabIndex": 6
|
||||
},
|
||||
{
|
||||
"id": "dankbar_widgets",
|
||||
"text": I18n.tr("Widgets"),
|
||||
@@ -238,33 +238,8 @@ Rectangle {
|
||||
"id": "network",
|
||||
"text": I18n.tr("Network"),
|
||||
"icon": "wifi",
|
||||
"dmsOnly": true,
|
||||
"children": [
|
||||
{
|
||||
"id": "network_status",
|
||||
"text": I18n.tr("Status"),
|
||||
"icon": "lan",
|
||||
"tabIndex": 7
|
||||
},
|
||||
{
|
||||
"id": "network_ethernet",
|
||||
"text": I18n.tr("Ethernet"),
|
||||
"icon": "settings_ethernet",
|
||||
"tabIndex": 39
|
||||
},
|
||||
{
|
||||
"id": "network_wifi",
|
||||
"text": I18n.tr("WiFi"),
|
||||
"icon": "wifi",
|
||||
"tabIndex": 40
|
||||
},
|
||||
{
|
||||
"id": "network_vpn",
|
||||
"text": I18n.tr("VPN"),
|
||||
"icon": "vpn_key",
|
||||
"tabIndex": 41
|
||||
}
|
||||
]
|
||||
"tabIndex": 7,
|
||||
"dmsOnly": true
|
||||
},
|
||||
{
|
||||
"id": "applications",
|
||||
|
||||
@@ -7,7 +7,6 @@ import qs.Widgets
|
||||
import qs.Services
|
||||
|
||||
Variants {
|
||||
readonly property var log: Log.scoped("BlurredWallpaperBackground")
|
||||
model: {
|
||||
if (SessionData.isGreeterMode) {
|
||||
return Quickshell.screens;
|
||||
@@ -33,8 +32,6 @@ Variants {
|
||||
|
||||
color: "transparent"
|
||||
|
||||
updatesEnabled: root.renderActive || root._settleFrames > 0
|
||||
|
||||
mask: Region {
|
||||
item: Item {}
|
||||
}
|
||||
@@ -88,6 +85,7 @@ Variants {
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
blurWallpaperWindow.updatesEnabled = Qt.binding(() => !root.source || root.effectActive || root._renderSettling || currentWallpaper.status === Image.Loading || nextWallpaper.status === Image.Loading);
|
||||
isInitialized = true;
|
||||
}
|
||||
|
||||
@@ -95,67 +93,51 @@ Variants {
|
||||
property real transitionProgress: 0
|
||||
readonly property bool transitioning: transitionAnimation.running
|
||||
property bool effectActive: false
|
||||
property bool _renderSettling: true
|
||||
property bool useNextForEffect: false
|
||||
readonly property var backingWindow: Window.window
|
||||
readonly property bool renderActive: !source || effectActive || currentWallpaper.status === Image.Loading || nextWallpaper.status === Image.Loading
|
||||
property int _settleFrames: 3
|
||||
|
||||
function invalidate() {
|
||||
_settleFrames = 3;
|
||||
backingWindow?.update();
|
||||
}
|
||||
|
||||
onRenderActiveChanged: invalidate()
|
||||
onBackingWindowChanged: invalidate()
|
||||
|
||||
Connections {
|
||||
target: root.backingWindow
|
||||
function onFrameSwapped() {
|
||||
if (root._settleFrames > 0)
|
||||
root._settleFrames--;
|
||||
}
|
||||
function onVisibleChanged() {
|
||||
root.invalidate();
|
||||
target: currentWallpaper
|
||||
function onStatusChanged() {
|
||||
if (currentWallpaper.status !== Image.Ready && currentWallpaper.status !== Image.Error)
|
||||
return;
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: blurWallpaperWindow
|
||||
function onWidthChanged() {
|
||||
root.invalidate();
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
function onHeightChanged() {
|
||||
root.invalidate();
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: Quickshell
|
||||
function onScreensChanged() {
|
||||
root.invalidate();
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: SettingsData
|
||||
function onWallpaperFillModeChanged() {
|
||||
root.invalidate();
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: IdleService
|
||||
function onIsShellLockedChanged() {
|
||||
if (IdleService.isShellLocked)
|
||||
return;
|
||||
root.invalidate();
|
||||
}
|
||||
}
|
||||
|
||||
function handleTransitionLoadError(failedSource) {
|
||||
log.warn("failed to load candidate wallpaper for", modelData.name + ":", failedSource);
|
||||
transitionDelayTimer.stop();
|
||||
transitionAnimation.stop();
|
||||
root.useNextForEffect = false;
|
||||
root.effectActive = false;
|
||||
root.transitionProgress = 0.0;
|
||||
nextWallpaper.source = "";
|
||||
Timer {
|
||||
id: renderSettleTimer
|
||||
interval: 1000
|
||||
onTriggered: root._renderSettling = false
|
||||
}
|
||||
|
||||
onSourceChanged: {
|
||||
@@ -182,6 +164,8 @@ Variants {
|
||||
transitionAnimation.stop();
|
||||
root.transitionProgress = 0.0;
|
||||
root.effectActive = false;
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
currentWallpaper.source = newSource;
|
||||
nextWallpaper.source = "";
|
||||
}
|
||||
@@ -210,6 +194,8 @@ Variants {
|
||||
transitionAnimation.stop();
|
||||
root.transitionProgress = 0;
|
||||
root.effectActive = false;
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
currentWallpaper.source = nextWallpaper.source;
|
||||
nextWallpaper.source = "";
|
||||
}
|
||||
@@ -218,6 +204,9 @@ Variants {
|
||||
return;
|
||||
}
|
||||
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
|
||||
nextWallpaper.source = newPath;
|
||||
|
||||
if (nextWallpaper.status === Image.Ready)
|
||||
@@ -226,7 +215,7 @@ Variants {
|
||||
|
||||
Loader {
|
||||
anchors.fill: parent
|
||||
active: !root.source || root.isColorSource || currentWallpaper.status === Image.Error
|
||||
active: !root.source || root.isColorSource
|
||||
asynchronous: true
|
||||
|
||||
sourceComponent: DankBackdrop {
|
||||
@@ -249,12 +238,6 @@ Variants {
|
||||
cache: true
|
||||
sourceSize: Qt.size(root.textureWidth, root.textureHeight)
|
||||
fillMode: root.getFillMode(SessionData.isGreeterMode ? GreetdSettings.wallpaperFillMode : SessionData.getMonitorWallpaperFillMode(modelData.name))
|
||||
|
||||
onStatusChanged: {
|
||||
if (status === Image.Error) {
|
||||
log.warn("failed to load active wallpaper for", modelData.name + ":", source);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Image {
|
||||
@@ -270,10 +253,6 @@ Variants {
|
||||
fillMode: root.getFillMode(SessionData.isGreeterMode ? GreetdSettings.wallpaperFillMode : SessionData.getMonitorWallpaperFillMode(modelData.name))
|
||||
|
||||
onStatusChanged: {
|
||||
if (status === Image.Error) {
|
||||
root.handleTransitionLoadError(source);
|
||||
return;
|
||||
}
|
||||
if (status !== Image.Ready)
|
||||
return;
|
||||
if (!root.transitioning) {
|
||||
@@ -350,6 +329,8 @@ Variants {
|
||||
root.useNextForEffect = false;
|
||||
nextWallpaper.source = "";
|
||||
root.transitionProgress = 0.0;
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
root.effectActive = false;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -151,7 +151,7 @@ Rectangle {
|
||||
iconColor: Theme.surfaceVariantText
|
||||
onClicked: {
|
||||
PopoutService.closeControlCenter();
|
||||
PopoutService.openSettingsWithTab(currentPreferenceIndex === 0 ? "network_ethernet" : "network_wifi");
|
||||
PopoutService.openSettingsWithTab("network");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -15,7 +15,6 @@ Item {
|
||||
property real barSpacing: 4
|
||||
property var barConfig: null
|
||||
property var blurBarWindow: null
|
||||
property real sectionAvailablePrimarySize: 0
|
||||
property bool overrideAxisLayout: false
|
||||
property bool forceVerticalLayout: false
|
||||
|
||||
@@ -360,7 +359,6 @@ Item {
|
||||
barSpacing: root.barSpacing
|
||||
barConfig: root.barConfig
|
||||
blurBarWindow: root.blurBarWindow
|
||||
sectionAvailablePrimarySize: root.sectionAvailablePrimarySize
|
||||
isFirst: index === 0
|
||||
isLast: index === centerRepeater.count - 1
|
||||
sectionSpacing: parent.itemSpacing
|
||||
|
||||
@@ -497,7 +497,6 @@ Item {
|
||||
widgetThickness: barWindow.widgetThickness
|
||||
barThickness: barWindow.effectiveBarThickness
|
||||
barSpacing: barConfig?.spacing ?? 4
|
||||
sectionAvailablePrimarySize: Math.max(1, hCenterSection.x > 0 ? hCenterSection.x : parent.width / 3)
|
||||
}
|
||||
|
||||
Binding {
|
||||
@@ -530,7 +529,6 @@ Item {
|
||||
widgetThickness: barWindow.widgetThickness
|
||||
barThickness: barWindow.effectiveBarThickness
|
||||
barSpacing: barConfig?.spacing ?? 4
|
||||
sectionAvailablePrimarySize: Math.max(1, hCenterSection.x > 0 ? parent.width - (hCenterSection.x + hCenterSection.width) : parent.width / 3)
|
||||
}
|
||||
|
||||
Binding {
|
||||
@@ -563,7 +561,6 @@ Item {
|
||||
widgetThickness: barWindow.widgetThickness
|
||||
barThickness: barWindow.effectiveBarThickness
|
||||
barSpacing: barConfig?.spacing ?? 4
|
||||
sectionAvailablePrimarySize: Math.max(1, hRightSection.x > 0 ? hRightSection.x - (hLeftSection.x + hLeftSection.width) : parent.width / 3)
|
||||
}
|
||||
|
||||
Binding {
|
||||
@@ -603,7 +600,6 @@ Item {
|
||||
widgetThickness: barWindow.widgetThickness
|
||||
barThickness: barWindow.effectiveBarThickness
|
||||
barSpacing: barConfig?.spacing ?? 4
|
||||
sectionAvailablePrimarySize: Math.max(1, vCenterSection.y > 0 ? vCenterSection.y : parent.height / 3)
|
||||
}
|
||||
|
||||
Binding {
|
||||
@@ -637,7 +633,6 @@ Item {
|
||||
widgetThickness: barWindow.widgetThickness
|
||||
barThickness: barWindow.effectiveBarThickness
|
||||
barSpacing: barConfig?.spacing ?? 4
|
||||
sectionAvailablePrimarySize: Math.max(1, vRightSection.y > 0 ? vRightSection.y - (vLeftSection.y + vLeftSection.height) : parent.height / 3)
|
||||
}
|
||||
|
||||
Binding {
|
||||
@@ -672,7 +667,6 @@ Item {
|
||||
widgetThickness: barWindow.widgetThickness
|
||||
barThickness: barWindow.effectiveBarThickness
|
||||
barSpacing: barConfig?.spacing ?? 4
|
||||
sectionAvailablePrimarySize: Math.max(1, vCenterSection.y > 0 ? parent.height - (vCenterSection.y + vCenterSection.height) : parent.height / 3)
|
||||
}
|
||||
|
||||
Binding {
|
||||
|
||||
@@ -286,6 +286,9 @@ PanelWindow {
|
||||
|
||||
readonly property bool isVertical: axis.isVertical
|
||||
|
||||
property bool gothCornersEnabled: barConfig?.gothCornersEnabled ?? false
|
||||
property real wingtipsRadius: barConfig?.gothCornerRadiusOverride ? (barConfig?.gothCornerRadiusValue ?? 12) : Theme.cornerRadius
|
||||
readonly property real _wingR: Math.max(0, wingtipsRadius)
|
||||
readonly property color _surfaceContainer: Theme.surfaceContainer
|
||||
readonly property string _barId: barConfig?.id ?? "default"
|
||||
property real _backgroundAlpha: barConfig?.transparency ?? 1.0
|
||||
@@ -297,30 +300,25 @@ PanelWindow {
|
||||
}
|
||||
readonly property real _dpr: CompositorService.getScreenScale(barWindow.screen)
|
||||
|
||||
property string screenName: modelData.name
|
||||
|
||||
readonly property bool usesConnectedFrameChrome: CompositorService.usesConnectedFrameChromeForScreen(screenName)
|
||||
readonly property bool usesFrameBarChrome: CompositorService.frameWindowVisibleForScreen(screenName)
|
||||
readonly property var renderBarConfig: SettingsData.effectiveBarConfigForRender(barConfig, usesFrameBarChrome)
|
||||
|
||||
property bool gothCornersEnabled: renderBarConfig?.gothCornersEnabled ?? false
|
||||
property real wingtipsRadius: renderBarConfig?.gothCornerRadiusOverride ? (renderBarConfig?.gothCornerRadiusValue ?? 12) : Theme.cornerRadius
|
||||
readonly property real _wingR: Math.max(0, wingtipsRadius)
|
||||
|
||||
// Shadow buffer: extra window space for shadow to render beyond bar bounds
|
||||
readonly property bool _shadowActive: (Theme.elevationEnabled && (typeof SettingsData !== "undefined" ? (SettingsData.barElevationEnabled ?? true) : false)) || (renderBarConfig?.shadowIntensity ?? 0) > 0
|
||||
readonly property bool _shadowActive: (Theme.elevationEnabled && (typeof SettingsData !== "undefined" ? (SettingsData.barElevationEnabled ?? true) : false)) || (barConfig?.shadowIntensity ?? 0) > 0
|
||||
readonly property real _shadowBuffer: {
|
||||
if (!_shadowActive)
|
||||
return 0;
|
||||
const hasOverride = (renderBarConfig?.shadowIntensity ?? 0) > 0;
|
||||
const hasOverride = (barConfig?.shadowIntensity ?? 0) > 0;
|
||||
if (hasOverride) {
|
||||
const blur = (renderBarConfig.shadowIntensity ?? 0) * 0.2;
|
||||
const blur = (barConfig.shadowIntensity ?? 0) * 0.2;
|
||||
const offset = blur * 0.5;
|
||||
return Theme.snap(Math.max(16, blur + offset + 8), _dpr);
|
||||
}
|
||||
return Theme.snap(Theme.elevationRenderPadding(Theme.elevationLevel2, "top", 4, 8, 16), _dpr);
|
||||
}
|
||||
|
||||
property string screenName: modelData.name
|
||||
|
||||
readonly property bool usesConnectedFrameChrome: CompositorService.usesConnectedFrameChromeForScreen(screenName)
|
||||
readonly property bool usesFrameBarChrome: CompositorService.frameWindowVisibleForScreen(screenName)
|
||||
|
||||
// Flatten/spacing collapse for maximized windows is only for frame-integrated layout.
|
||||
// When the bar draws its own pill, keep rounded corners and spacing like the dock.
|
||||
readonly property bool flattenForMaximizedWindow: !SettingsData.frameEnabled || usesFrameBarChrome
|
||||
@@ -556,8 +554,8 @@ PanelWindow {
|
||||
}
|
||||
|
||||
screen: modelData
|
||||
implicitHeight: !isVertical ? Theme.px(effectiveBarThickness + effectiveSpacing + ((renderBarConfig?.gothCornersEnabled ?? false) && !hasMaximizedToplevel ? _wingR : 0), _dpr) + _shadowBuffer : 0
|
||||
implicitWidth: isVertical ? Theme.px(effectiveBarThickness + effectiveSpacing + ((renderBarConfig?.gothCornersEnabled ?? false) && !hasMaximizedToplevel ? _wingR : 0), _dpr) + _shadowBuffer : 0
|
||||
implicitHeight: !isVertical ? Theme.px(effectiveBarThickness + effectiveSpacing + ((barConfig?.gothCornersEnabled ?? false) && !hasMaximizedToplevel ? _wingR : 0), _dpr) + _shadowBuffer : 0
|
||||
implicitWidth: isVertical ? Theme.px(effectiveBarThickness + effectiveSpacing + ((barConfig?.gothCornersEnabled ?? false) && !hasMaximizedToplevel ? _wingR : 0), _dpr) + _shadowBuffer : 0
|
||||
color: "transparent"
|
||||
|
||||
Component.onCompleted: {
|
||||
@@ -954,7 +952,7 @@ PanelWindow {
|
||||
id: barBackground
|
||||
barWindow: barWindow
|
||||
axis: axis
|
||||
barConfig: barWindow.renderBarConfig
|
||||
barConfig: barWindow.barConfig
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
|
||||
@@ -14,7 +14,6 @@ Item {
|
||||
property real barSpacing: 4
|
||||
property var barConfig: null
|
||||
property var blurBarWindow: null
|
||||
property real sectionAvailablePrimarySize: 0
|
||||
property bool overrideAxisLayout: false
|
||||
property bool forceVerticalLayout: false
|
||||
|
||||
@@ -62,7 +61,6 @@ Item {
|
||||
barSpacing: root.barSpacing
|
||||
barConfig: root.barConfig
|
||||
blurBarWindow: root.blurBarWindow
|
||||
sectionAvailablePrimarySize: root.sectionAvailablePrimarySize
|
||||
isFirst: index === 0
|
||||
isLast: index === rowRepeater.count - 1
|
||||
sectionSpacing: parent.rowSpacing
|
||||
@@ -108,7 +106,6 @@ Item {
|
||||
barSpacing: root.barSpacing
|
||||
barConfig: root.barConfig
|
||||
blurBarWindow: root.blurBarWindow
|
||||
sectionAvailablePrimarySize: root.sectionAvailablePrimarySize
|
||||
isFirst: index === 0
|
||||
isLast: index === columnRepeater.count - 1
|
||||
sectionSpacing: parent.columnSpacing
|
||||
|
||||
@@ -14,7 +14,6 @@ Item {
|
||||
property real barSpacing: 4
|
||||
property var barConfig: null
|
||||
property var blurBarWindow: null
|
||||
property real sectionAvailablePrimarySize: 0
|
||||
property bool overrideAxisLayout: false
|
||||
property bool forceVerticalLayout: false
|
||||
|
||||
@@ -64,7 +63,6 @@ Item {
|
||||
barSpacing: root.barSpacing
|
||||
barConfig: root.barConfig
|
||||
blurBarWindow: root.blurBarWindow
|
||||
sectionAvailablePrimarySize: root.sectionAvailablePrimarySize
|
||||
isFirst: index === 0
|
||||
isLast: index === rowRepeater.count - 1
|
||||
sectionSpacing: parent.rowSpacing
|
||||
@@ -110,7 +108,6 @@ Item {
|
||||
barSpacing: root.barSpacing
|
||||
barConfig: root.barConfig
|
||||
blurBarWindow: root.blurBarWindow
|
||||
sectionAvailablePrimarySize: root.sectionAvailablePrimarySize
|
||||
isFirst: index === 0
|
||||
isLast: index === columnRepeater.count - 1
|
||||
sectionSpacing: parent.columnSpacing
|
||||
|
||||
@@ -17,7 +17,6 @@ Loader {
|
||||
property real barSpacing: 4
|
||||
property var barConfig: null
|
||||
property var blurBarWindow: null
|
||||
property real sectionAvailablePrimarySize: 0
|
||||
property bool isFirst: false
|
||||
property bool isLast: false
|
||||
property real sectionSpacing: 0
|
||||
@@ -142,14 +141,6 @@ Loader {
|
||||
restoreMode: Binding.RestoreNone
|
||||
}
|
||||
|
||||
Binding {
|
||||
target: root.item
|
||||
when: root.item && "sectionAvailablePrimarySize" in root.item
|
||||
property: "sectionAvailablePrimarySize"
|
||||
value: root.sectionAvailablePrimarySize
|
||||
restoreMode: Binding.RestoreNone
|
||||
}
|
||||
|
||||
Binding {
|
||||
target: root.item
|
||||
when: root.item && "isLeftBarEdge" in root.item
|
||||
|
||||
@@ -32,20 +32,9 @@ BasePill {
|
||||
}
|
||||
|
||||
readonly property var notepadInstance: resolveNotepadInstance()
|
||||
readonly property bool popoutDefault: SettingsData.notepadDefaultMode === "popout"
|
||||
readonly property bool isActive: popoutDefault ? (PopoutService.notepadPopout?.visible ?? false) : (notepadInstance?.isVisible ?? false)
|
||||
readonly property bool isActive: notepadInstance?.isVisible ?? false
|
||||
property bool isAutoHideBar: false
|
||||
|
||||
function showActiveSurface() {
|
||||
if (root.popoutDefault) {
|
||||
PopoutService.openNotepadPopout();
|
||||
return;
|
||||
}
|
||||
const instance = prepareNotepadInstance(root.notepadInstance);
|
||||
if (instance && typeof instance.show === "function")
|
||||
instance.show();
|
||||
}
|
||||
|
||||
function prepareNotepadInstance(instance) {
|
||||
if (instance)
|
||||
instance.triggerUsesOverlayLayer = root.barUsesOverlayLayer;
|
||||
@@ -86,14 +75,20 @@ BasePill {
|
||||
function openTabByIndex(tabIndex) {
|
||||
if (tabIndex < 0)
|
||||
return;
|
||||
showActiveSurface();
|
||||
const instance = prepareNotepadInstance(root.notepadInstance);
|
||||
if (instance && typeof instance.show === "function") {
|
||||
instance.show();
|
||||
}
|
||||
Qt.callLater(() => {
|
||||
NotepadStorageService.switchToTab(tabIndex);
|
||||
});
|
||||
}
|
||||
|
||||
function openNewNote() {
|
||||
showActiveSurface();
|
||||
const instance = prepareNotepadInstance(root.notepadInstance);
|
||||
if (instance && typeof instance.show === "function") {
|
||||
instance.show();
|
||||
}
|
||||
Qt.callLater(() => {
|
||||
NotepadStorageService.createNewTab();
|
||||
});
|
||||
@@ -152,10 +147,6 @@ BasePill {
|
||||
openContextMenu();
|
||||
return;
|
||||
}
|
||||
if (root.popoutDefault) {
|
||||
PopoutService.toggleNotepadPopout();
|
||||
return;
|
||||
}
|
||||
const inst = prepareNotepadInstance(root.notepadInstance);
|
||||
if (inst) {
|
||||
inst.toggle();
|
||||
|
||||
@@ -22,10 +22,6 @@ BasePill {
|
||||
property bool isAtBottom: false
|
||||
property bool isAutoHideBar: false
|
||||
property bool useOverflowPopup: !widgetData?.trayUseInlineExpansion
|
||||
property bool useSingleLineOverflowPopup: widgetData?.trayPopupSingleLine ?? SettingsData.trayPopupSingleLine
|
||||
property bool useAutomaticOverflow: widgetData?.trayAutoOverflow ?? SettingsData.trayAutoOverflow
|
||||
property int configuredMaxVisibleItems: widgetData?.trayMaxVisibleItems ?? SettingsData.trayMaxVisibleItems
|
||||
property real sectionAvailablePrimarySize: 0
|
||||
readonly property var hiddenTrayIds: {
|
||||
const envValue = Quickshell.env("DMS_HIDE_TRAYIDS") || "";
|
||||
return envValue ? envValue.split(",").map(id => id.trim().toLowerCase()) : [];
|
||||
@@ -150,32 +146,12 @@ BasePill {
|
||||
|
||||
readonly property var allSortedTrayItems: sortByPreferredOrder(allTrayItems, _trayOrderTrigger)
|
||||
readonly property var allSortedTrayItemKeys: allSortedTrayItems.map(item => getTrayItemKey(item))
|
||||
readonly property var visibleSortedTrayItems: allSortedTrayItems.filter(item => !SessionData.isHiddenTrayId(root.getTrayItemKey(item)))
|
||||
readonly property int automaticVisibleItemLimit: {
|
||||
if (!root.useAutomaticOverflow)
|
||||
return root.visibleSortedTrayItems.length;
|
||||
|
||||
const explicitLimit = Number(root.configuredMaxVisibleItems || 0);
|
||||
if (explicitLimit > 0)
|
||||
return Math.max(1, Math.min(root.visibleSortedTrayItems.length, explicitLimit));
|
||||
|
||||
const scale = (typeof CompositorService !== "undefined" && CompositorService.getScreenScale) ? Math.max(1, CompositorService.getScreenScale(root.parentScreen)) : 1;
|
||||
const sectionPrimary = root.sectionAvailablePrimarySize > 0 ? root.sectionAvailablePrimarySize : (root.isVerticalOrientation ? (root.parentScreen?.height || 0) : (root.parentScreen?.width || 0));
|
||||
const logicalPrimary = sectionPrimary > 0 ? (sectionPrimary / scale) : 640;
|
||||
const maxTrayShare = root.isVerticalOrientation ? 0.55 : 0.50;
|
||||
const itemSize = Math.max(1, root.trayItemSize);
|
||||
const slots = Math.floor((logicalPrimary * maxTrayShare) / itemSize);
|
||||
return Math.max(2, Math.min(10, Math.min(root.visibleSortedTrayItems.length, slots)));
|
||||
}
|
||||
readonly property var mainBarItemsRaw: visibleSortedTrayItems.slice(0, automaticVisibleItemLimit)
|
||||
readonly property var mainBarItemsRaw: allSortedTrayItems.filter(item => !SessionData.isHiddenTrayId(root.getTrayItemKey(item)))
|
||||
readonly property var mainBarItems: mainBarItemsRaw.map((item, idx) => ({
|
||||
key: getTrayItemKey(item),
|
||||
item: item
|
||||
}))
|
||||
readonly property var autoOverflowBarItems: visibleSortedTrayItems.slice(automaticVisibleItemLimit)
|
||||
readonly property var manualHiddenBarItems: allSortedTrayItems.filter(item => SessionData.isHiddenTrayId(root.getTrayItemKey(item)))
|
||||
readonly property var hiddenBarItemKeys: manualHiddenBarItems.concat(autoOverflowBarItems).map(item => root.getTrayItemKey(item))
|
||||
readonly property var hiddenBarItems: allSortedTrayItems.filter(item => hiddenBarItemKeys.indexOf(root.getTrayItemKey(item)) !== -1)
|
||||
readonly property var hiddenBarItems: allSortedTrayItems.filter(item => SessionData.isHiddenTrayId(root.getTrayItemKey(item)))
|
||||
readonly property string trayIconTintMode: {
|
||||
const configuredMode = SettingsData.systemTrayIconTintMode || "none";
|
||||
switch (configuredMode) {
|
||||
@@ -243,10 +219,6 @@ BasePill {
|
||||
|
||||
const fromKey = mainBarItems[visibleFromIndex]?.key ?? null;
|
||||
const toKey = mainBarItems[visibleToIndex]?.key ?? null;
|
||||
moveTrayItemKeyInFullOrder(fromKey, toKey);
|
||||
}
|
||||
|
||||
function moveTrayItemKeyInFullOrder(fromKey, toKey) {
|
||||
if (!fromKey || !toKey)
|
||||
return;
|
||||
|
||||
@@ -261,103 +233,10 @@ BasePill {
|
||||
SessionData.setTrayItemOrder(fullOrder);
|
||||
}
|
||||
|
||||
function promoteTrayItemToBar(item) {
|
||||
const itemKey = getTrayItemKey(item);
|
||||
if (!itemKey)
|
||||
return;
|
||||
if (SessionData.isHiddenTrayId(itemKey)) {
|
||||
SessionData.showTrayId(itemKey);
|
||||
return;
|
||||
}
|
||||
|
||||
const fullOrder = [...allSortedTrayItemKeys];
|
||||
const fromIndex = fullOrder.indexOf(itemKey);
|
||||
if (fromIndex < 0)
|
||||
return;
|
||||
const movedKey = fullOrder.splice(fromIndex, 1)[0];
|
||||
const targetIndex = Math.max(0, Math.min(root.automaticVisibleItemLimit - 1, fullOrder.length));
|
||||
fullOrder.splice(targetIndex, 0, movedKey);
|
||||
SessionData.setTrayItemOrder(fullOrder);
|
||||
}
|
||||
|
||||
function isManualHiddenTrayItem(item) {
|
||||
return SessionData.isHiddenTrayId(getTrayItemKey(item));
|
||||
}
|
||||
|
||||
function isAutoOverflowTrayItem(item) {
|
||||
const key = getTrayItemKey(item);
|
||||
return key && !isManualHiddenTrayItem(item) && root.autoOverflowBarItems.some(overflowItem => getTrayItemKey(overflowItem) === key);
|
||||
}
|
||||
|
||||
function dragShiftOffset(index, draggedIndex, dropTargetIndex, shiftAmount) {
|
||||
if (draggedIndex < 0 || index === draggedIndex || dropTargetIndex < 0)
|
||||
return 0;
|
||||
if (draggedIndex < dropTargetIndex && index > draggedIndex && index <= dropTargetIndex)
|
||||
return -shiftAmount;
|
||||
if (draggedIndex > dropTargetIndex && index >= dropTargetIndex && index < draggedIndex)
|
||||
return shiftAmount;
|
||||
return 0;
|
||||
}
|
||||
|
||||
function beginMainDrag(visualIndex, reversed) {
|
||||
root.draggedIndex = reversed ? (root.mainBarItems.length - 1 - visualIndex) : visualIndex;
|
||||
root.dropTargetIndex = root.draggedIndex;
|
||||
}
|
||||
|
||||
function updateMainDrag(axisOffset, visualIndex, reversed) {
|
||||
const itemSize = root.trayItemSize;
|
||||
const slotOffset = Math.round(axisOffset / itemSize);
|
||||
const visualTargetIndex = Math.max(0, Math.min(root.mainBarItems.length - 1, visualIndex + slotOffset));
|
||||
const newTargetIndex = reversed ? (root.mainBarItems.length - 1 - visualTargetIndex) : visualTargetIndex;
|
||||
if (newTargetIndex !== root.dropTargetIndex)
|
||||
root.dropTargetIndex = newTargetIndex;
|
||||
}
|
||||
|
||||
function finishMainDrag() {
|
||||
const didReorder = root.dropTargetIndex >= 0 && root.dropTargetIndex !== root.draggedIndex;
|
||||
if (didReorder) {
|
||||
root.suppressShiftAnimation = true;
|
||||
root.moveTrayItemInFullOrder(root.draggedIndex, root.dropTargetIndex);
|
||||
Qt.callLater(() => root.suppressShiftAnimation = false);
|
||||
}
|
||||
root.draggedIndex = -1;
|
||||
root.dropTargetIndex = -1;
|
||||
return didReorder;
|
||||
}
|
||||
|
||||
function beginPopupDrag(index) {
|
||||
root.popupDraggedIndex = index;
|
||||
root.popupDropTargetIndex = index;
|
||||
}
|
||||
|
||||
function updatePopupDrag(axisOffset, index) {
|
||||
const itemSize = root.trayItemSize + 6;
|
||||
const slotOffset = Math.round(axisOffset / itemSize);
|
||||
const newTargetIndex = Math.max(0, Math.min(root.hiddenBarItems.length - 1, index + slotOffset));
|
||||
if (newTargetIndex !== root.popupDropTargetIndex)
|
||||
root.popupDropTargetIndex = newTargetIndex;
|
||||
}
|
||||
|
||||
function finishPopupDrag() {
|
||||
const didReorder = root.popupDropTargetIndex >= 0 && root.popupDropTargetIndex !== root.popupDraggedIndex;
|
||||
if (didReorder) {
|
||||
const fromItem = root.hiddenBarItems[root.popupDraggedIndex];
|
||||
const toItem = root.hiddenBarItems[root.popupDropTargetIndex];
|
||||
root.suppressShiftAnimation = true;
|
||||
root.moveTrayItemKeyInFullOrder(root.getTrayItemKey(fromItem), root.getTrayItemKey(toItem));
|
||||
Qt.callLater(() => root.suppressShiftAnimation = false);
|
||||
}
|
||||
root.popupDraggedIndex = -1;
|
||||
root.popupDropTargetIndex = -1;
|
||||
return didReorder;
|
||||
}
|
||||
|
||||
property int draggedIndex: -1
|
||||
property int dropTargetIndex: -1
|
||||
property int popupDraggedIndex: -1
|
||||
property int popupDropTargetIndex: -1
|
||||
property bool suppressShiftAnimation: false
|
||||
readonly property bool hasHiddenItems: hiddenBarItems.length > 0
|
||||
readonly property bool hasHiddenItems: allTrayItems.length > mainBarItems.length
|
||||
readonly property bool inlineExpanded: hasHiddenItems && !useOverflowPopup && menuOpen
|
||||
visible: allTrayItems.length > 0
|
||||
opacity: allTrayItems.length > 0 ? 1 : 0
|
||||
@@ -472,7 +351,22 @@ BasePill {
|
||||
height: root.barThickness
|
||||
z: dragHandler.dragging ? 100 : 0
|
||||
|
||||
property real shiftOffset: root.dragShiftOffset(index, root.draggedIndex, root.dropTargetIndex, root.trayItemSize)
|
||||
property real shiftOffset: {
|
||||
if (root.draggedIndex < 0)
|
||||
return 0;
|
||||
if (index === root.draggedIndex)
|
||||
return 0;
|
||||
const dragIdx = root.draggedIndex;
|
||||
const dropIdx = root.dropTargetIndex;
|
||||
const shiftAmount = root.trayItemSize;
|
||||
if (dropIdx < 0)
|
||||
return 0;
|
||||
if (dragIdx < dropIdx && index > dragIdx && index <= dropIdx)
|
||||
return -shiftAmount;
|
||||
if (dragIdx > dropIdx && index >= dropIdx && index < dragIdx)
|
||||
return shiftAmount;
|
||||
return 0;
|
||||
}
|
||||
|
||||
transform: Translate {
|
||||
x: delegateRoot.shiftOffset
|
||||
@@ -572,12 +466,19 @@ BasePill {
|
||||
onReleased: mouse => {
|
||||
longPressTimer.stop();
|
||||
const wasDragging = dragHandler.dragging;
|
||||
if (wasDragging)
|
||||
root.finishMainDrag();
|
||||
const didReorder = wasDragging && root.dropTargetIndex >= 0 && root.dropTargetIndex !== root.draggedIndex;
|
||||
|
||||
if (didReorder) {
|
||||
root.suppressShiftAnimation = true;
|
||||
root.moveTrayItemInFullOrder(root.draggedIndex, root.dropTargetIndex);
|
||||
Qt.callLater(() => root.suppressShiftAnimation = false);
|
||||
}
|
||||
|
||||
dragHandler.longPressing = false;
|
||||
dragHandler.dragging = false;
|
||||
dragHandler.dragAxisOffset = 0;
|
||||
root.draggedIndex = -1;
|
||||
root.dropTargetIndex = -1;
|
||||
|
||||
if (wasDragging || mouse.button !== Qt.LeftButton)
|
||||
return;
|
||||
@@ -600,7 +501,8 @@ BasePill {
|
||||
const distance = Math.abs(mouse.x - dragHandler.dragStartPos.x);
|
||||
if (distance > 5) {
|
||||
dragHandler.dragging = true;
|
||||
root.beginMainDrag(index, root.reverseInlineHorizontal);
|
||||
root.draggedIndex = root.reverseInlineHorizontal ? (root.mainBarItems.length - 1 - index) : index;
|
||||
root.dropTargetIndex = root.draggedIndex;
|
||||
}
|
||||
}
|
||||
if (!dragHandler.dragging)
|
||||
@@ -608,7 +510,13 @@ BasePill {
|
||||
|
||||
const axisOffset = mouse.x - dragHandler.dragStartPos.x;
|
||||
dragHandler.dragAxisOffset = axisOffset;
|
||||
root.updateMainDrag(axisOffset, index, root.reverseInlineHorizontal);
|
||||
const itemSize = root.trayItemSize;
|
||||
const slotOffset = Math.round(axisOffset / itemSize);
|
||||
const visualTargetIndex = Math.max(0, Math.min(root.mainBarItems.length - 1, index + slotOffset));
|
||||
const newTargetIndex = root.reverseInlineHorizontal ? (root.mainBarItems.length - 1 - visualTargetIndex) : visualTargetIndex;
|
||||
if (newTargetIndex !== root.dropTargetIndex) {
|
||||
root.dropTargetIndex = newTargetIndex;
|
||||
}
|
||||
}
|
||||
|
||||
onClicked: mouse => {
|
||||
@@ -798,7 +706,22 @@ BasePill {
|
||||
height: root.trayItemSize
|
||||
z: dragHandler.dragging ? 100 : 0
|
||||
|
||||
property real shiftOffset: root.dragShiftOffset(index, root.draggedIndex, root.dropTargetIndex, root.trayItemSize)
|
||||
property real shiftOffset: {
|
||||
if (root.draggedIndex < 0)
|
||||
return 0;
|
||||
if (index === root.draggedIndex)
|
||||
return 0;
|
||||
const dragIdx = root.draggedIndex;
|
||||
const dropIdx = root.dropTargetIndex;
|
||||
const shiftAmount = root.trayItemSize;
|
||||
if (dropIdx < 0)
|
||||
return 0;
|
||||
if (dragIdx < dropIdx && index > dragIdx && index <= dropIdx)
|
||||
return -shiftAmount;
|
||||
if (dragIdx > dropIdx && index >= dropIdx && index < dragIdx)
|
||||
return shiftAmount;
|
||||
return 0;
|
||||
}
|
||||
|
||||
transform: Translate {
|
||||
y: shiftOffset
|
||||
@@ -898,12 +821,19 @@ BasePill {
|
||||
onReleased: mouse => {
|
||||
longPressTimer.stop();
|
||||
const wasDragging = dragHandler.dragging;
|
||||
if (wasDragging)
|
||||
root.finishMainDrag();
|
||||
const didReorder = wasDragging && root.dropTargetIndex >= 0 && root.dropTargetIndex !== root.draggedIndex;
|
||||
|
||||
if (didReorder) {
|
||||
root.suppressShiftAnimation = true;
|
||||
root.moveTrayItemInFullOrder(root.draggedIndex, root.dropTargetIndex);
|
||||
Qt.callLater(() => root.suppressShiftAnimation = false);
|
||||
}
|
||||
|
||||
dragHandler.longPressing = false;
|
||||
dragHandler.dragging = false;
|
||||
dragHandler.dragAxisOffset = 0;
|
||||
root.draggedIndex = -1;
|
||||
root.dropTargetIndex = -1;
|
||||
|
||||
if (wasDragging || mouse.button !== Qt.LeftButton)
|
||||
return;
|
||||
@@ -926,7 +856,8 @@ BasePill {
|
||||
const distance = Math.abs(mouse.y - dragHandler.dragStartPos.y);
|
||||
if (distance > 5) {
|
||||
dragHandler.dragging = true;
|
||||
root.beginMainDrag(index, false);
|
||||
root.draggedIndex = index;
|
||||
root.dropTargetIndex = root.draggedIndex;
|
||||
}
|
||||
}
|
||||
if (!dragHandler.dragging)
|
||||
@@ -934,7 +865,12 @@ BasePill {
|
||||
|
||||
const axisOffset = mouse.y - dragHandler.dragStartPos.y;
|
||||
dragHandler.dragAxisOffset = axisOffset;
|
||||
root.updateMainDrag(axisOffset, index, false);
|
||||
const itemSize = root.trayItemSize;
|
||||
const slotOffset = Math.round(axisOffset / itemSize);
|
||||
const newTargetIndex = Math.max(0, Math.min(root.mainBarItems.length - 1, index + slotOffset));
|
||||
if (newTargetIndex !== root.dropTargetIndex) {
|
||||
root.dropTargetIndex = newTargetIndex;
|
||||
}
|
||||
}
|
||||
|
||||
onClicked: mouse => {
|
||||
@@ -1179,12 +1115,11 @@ BasePill {
|
||||
}
|
||||
|
||||
function updatePosition() {
|
||||
// Window-local maps directly to screen-local because the bar window spans the
|
||||
// full screen edge; this avoids mixing mapToGlobal with a separately-tracked
|
||||
// screen.x/.y origin, which desync on non-primary monitors and after DPMS/hotplug.
|
||||
const localPos = root.mapToItem(null, 0, 0);
|
||||
const relativeX = localPos.x;
|
||||
const relativeY = localPos.y;
|
||||
const globalPos = root.mapToGlobal(0, 0);
|
||||
const screenX = screen.x || 0;
|
||||
const screenY = screen.y || 0;
|
||||
const relativeX = globalPos.x - screenX;
|
||||
const relativeY = globalPos.y - screenY;
|
||||
|
||||
if (root.isVerticalOrientation) {
|
||||
const edge = root.axis?.edge;
|
||||
@@ -1201,38 +1136,20 @@ BasePill {
|
||||
id: menuContainer
|
||||
objectName: "overflowMenuContainer"
|
||||
|
||||
readonly property bool popupUsesVerticalLine: root.useSingleLineOverflowPopup && root.isVerticalOrientation
|
||||
readonly property real popupPadding: Theme.spacingS + (popupUsesVerticalLine ? 3 : 0)
|
||||
|
||||
readonly property real rawWidth: {
|
||||
const itemCount = root.hiddenBarItems.length;
|
||||
if (itemCount === 0)
|
||||
return 0;
|
||||
if (popupUsesVerticalLine)
|
||||
return root.trayItemSize + 4 + popupPadding * 2;
|
||||
const cols = root.useSingleLineOverflowPopup ? itemCount : Math.min(5, itemCount);
|
||||
const cols = Math.min(5, itemCount);
|
||||
const itemSize = root.trayItemSize + 4;
|
||||
const spacing = 2;
|
||||
const desiredWidth = cols * itemSize + (cols - 1) * spacing + popupPadding * 2;
|
||||
if (!root.useSingleLineOverflowPopup)
|
||||
return desiredWidth;
|
||||
const maxWidth = Math.max(itemSize + popupPadding * 2, overflowMenu.maskWidth - 20);
|
||||
return Math.min(desiredWidth, maxWidth);
|
||||
return cols * itemSize + (cols - 1) * spacing + Theme.spacingS * 2;
|
||||
}
|
||||
readonly property real rawHeight: {
|
||||
const itemCount = root.hiddenBarItems.length;
|
||||
if (itemCount === 0)
|
||||
return 0;
|
||||
const cols = Math.min(5, itemCount);
|
||||
const rows = Math.ceil(itemCount / cols);
|
||||
const itemSize = root.trayItemSize + 4;
|
||||
const spacing = 2;
|
||||
if (popupUsesVerticalLine) {
|
||||
const desiredHeight = itemCount * itemSize + (itemCount - 1) * spacing + popupPadding * 2;
|
||||
const maxHeight = Math.max(itemSize + popupPadding * 2, overflowMenu.maskHeight - 20);
|
||||
return Math.min(desiredHeight, maxHeight);
|
||||
}
|
||||
const cols = root.useSingleLineOverflowPopup ? itemCount : Math.min(5, itemCount);
|
||||
const rows = Math.ceil(itemCount / cols);
|
||||
return rows * itemSize + (rows - 1) * spacing + popupPadding * 2;
|
||||
return rows * itemSize + (rows - 1) * spacing + Theme.spacingS * 2;
|
||||
}
|
||||
|
||||
readonly property real alignedWidth: Theme.px(rawWidth, overflowMenu.dpr)
|
||||
@@ -1313,161 +1230,76 @@ BasePill {
|
||||
z: 100
|
||||
}
|
||||
|
||||
Flickable {
|
||||
Grid {
|
||||
id: menuGrid
|
||||
anchors.centerIn: parent
|
||||
width: parent.width - menuContainer.popupPadding * 2
|
||||
height: parent.height - menuContainer.popupPadding * 2
|
||||
contentWidth: menuGrid.implicitWidth
|
||||
contentHeight: menuGrid.implicitHeight
|
||||
boundsBehavior: Flickable.StopAtBounds
|
||||
clip: true
|
||||
interactive: root.useSingleLineOverflowPopup && (menuContainer.popupUsesVerticalLine ? contentHeight > height : contentWidth > width)
|
||||
columns: Math.min(5, root.hiddenBarItems.length)
|
||||
spacing: 2
|
||||
rowSpacing: 2
|
||||
|
||||
Grid {
|
||||
id: menuGrid
|
||||
anchors.verticalCenter: menuContainer.popupUsesVerticalLine ? undefined : parent.verticalCenter
|
||||
anchors.horizontalCenter: menuContainer.popupUsesVerticalLine ? parent.horizontalCenter : undefined
|
||||
columns: menuContainer.popupUsesVerticalLine ? 1 : (root.useSingleLineOverflowPopup ? root.hiddenBarItems.length : Math.min(5, root.hiddenBarItems.length))
|
||||
spacing: 2
|
||||
rowSpacing: 2
|
||||
Repeater {
|
||||
model: root.hiddenBarItems
|
||||
|
||||
Repeater {
|
||||
model: root.hiddenBarItems
|
||||
delegate: Rectangle {
|
||||
property var trayItem: modelData
|
||||
property string iconSource: root.trayIconSourceFor(trayItem)
|
||||
|
||||
delegate: Rectangle {
|
||||
id: overflowItemRoot
|
||||
property var trayItem: modelData
|
||||
property string itemKey: root.getTrayItemKey(trayItem)
|
||||
property string iconSource: root.trayIconSourceFor(trayItem)
|
||||
width: root.trayItemSize + 4
|
||||
height: root.trayItemSize + 4
|
||||
radius: Theme.cornerRadius
|
||||
color: itemArea.containsMouse ? BlurService.hoverColor(Theme.widgetBaseHoverColor) : Theme.withAlpha(Theme.surfaceContainer, 0)
|
||||
|
||||
width: root.trayItemSize + 4
|
||||
height: root.trayItemSize + 4
|
||||
z: popupDragHandler.dragging ? 100 : 0
|
||||
radius: Theme.cornerRadius
|
||||
color: itemArea.containsMouse ? BlurService.hoverColor(Theme.widgetBaseHoverColor) : Theme.withAlpha(Theme.surfaceContainer, 0)
|
||||
border.width: popupDragHandler.dragging ? 2 : 0
|
||||
border.color: Theme.primary
|
||||
opacity: popupDragHandler.dragging ? 0.8 : 1.0
|
||||
|
||||
property real shiftOffset: root.dragShiftOffset(index, root.popupDraggedIndex, root.popupDropTargetIndex, root.trayItemSize + 6)
|
||||
|
||||
transform: Translate {
|
||||
x: !menuContainer.popupUsesVerticalLine ? overflowItemRoot.shiftOffset + (popupDragHandler.dragging ? popupDragHandler.dragAxisOffset : 0) : 0
|
||||
y: menuContainer.popupUsesVerticalLine ? overflowItemRoot.shiftOffset + (popupDragHandler.dragging ? popupDragHandler.dragAxisOffset : 0) : 0
|
||||
Behavior on x {
|
||||
enabled: !root.suppressShiftAnimation && !menuContainer.popupUsesVerticalLine
|
||||
NumberAnimation {
|
||||
duration: 150
|
||||
easing.type: Easing.OutCubic
|
||||
}
|
||||
}
|
||||
Behavior on y {
|
||||
enabled: !root.suppressShiftAnimation && menuContainer.popupUsesVerticalLine
|
||||
NumberAnimation {
|
||||
duration: 150
|
||||
easing.type: Easing.OutCubic
|
||||
}
|
||||
}
|
||||
IconImage {
|
||||
id: menuIconImg
|
||||
anchors.centerIn: parent
|
||||
width: Theme.barIconSize(root.barThickness, undefined, root.barConfig?.maximizeWidgetIcons, root.barConfig?.iconScale)
|
||||
height: Theme.barIconSize(root.barThickness, undefined, root.barConfig?.maximizeWidgetIcons, root.barConfig?.iconScale)
|
||||
source: parent.iconSource
|
||||
asynchronous: true
|
||||
smooth: true
|
||||
mipmap: true
|
||||
visible: status === Image.Ready
|
||||
layer.enabled: root.trayIconTintEnabled
|
||||
layer.effect: MultiEffect {
|
||||
saturation: root.trayIconSaturation
|
||||
colorization: root.trayIconColorization
|
||||
colorizationColor: root.trayIconTintColor
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: popupDragHandler
|
||||
anchors.fill: parent
|
||||
property bool dragging: false
|
||||
property point dragStartPos: Qt.point(0, 0)
|
||||
property real dragAxisOffset: 0
|
||||
property bool longPressing: false
|
||||
|
||||
Timer {
|
||||
id: popupLongPressTimer
|
||||
interval: 400
|
||||
repeat: false
|
||||
onTriggered: popupDragHandler.longPressing = true
|
||||
}
|
||||
StyledText {
|
||||
anchors.centerIn: parent
|
||||
visible: !menuIconImg.visible
|
||||
text: {
|
||||
const itemId = trayItem?.id || "";
|
||||
if (!itemId)
|
||||
return "?";
|
||||
return itemId.charAt(0).toUpperCase();
|
||||
}
|
||||
font.pixelSize: 10
|
||||
color: Theme.widgetTextColor
|
||||
}
|
||||
|
||||
IconImage {
|
||||
id: menuIconImg
|
||||
anchors.centerIn: parent
|
||||
width: Theme.barIconSize(root.barThickness, undefined, root.barConfig?.maximizeWidgetIcons, root.barConfig?.iconScale)
|
||||
height: Theme.barIconSize(root.barThickness, undefined, root.barConfig?.maximizeWidgetIcons, root.barConfig?.iconScale)
|
||||
source: parent.iconSource
|
||||
asynchronous: true
|
||||
smooth: true
|
||||
mipmap: true
|
||||
visible: status === Image.Ready
|
||||
layer.enabled: root.trayIconTintEnabled
|
||||
layer.effect: MultiEffect {
|
||||
saturation: root.trayIconSaturation
|
||||
colorization: root.trayIconColorization
|
||||
colorizationColor: root.trayIconTintColor
|
||||
MouseArea {
|
||||
id: itemArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: mouse => {
|
||||
if (!trayItem)
|
||||
return;
|
||||
if (mouse.button === Qt.LeftButton && !trayItem.onlyMenu) {
|
||||
trayItem.activate();
|
||||
root.menuOpen = false;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
anchors.centerIn: parent
|
||||
visible: !menuIconImg.visible
|
||||
text: {
|
||||
const itemId = trayItem?.id || "";
|
||||
if (!itemId)
|
||||
return "?";
|
||||
return itemId.charAt(0).toUpperCase();
|
||||
}
|
||||
font.pixelSize: 10
|
||||
color: Theme.widgetTextColor
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: itemArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
||||
cursorShape: popupDragHandler.longPressing ? Qt.DragMoveCursor : Qt.PointingHandCursor
|
||||
onPressed: mouse => {
|
||||
if (mouse.button === Qt.LeftButton) {
|
||||
popupDragHandler.dragStartPos = Qt.point(mouse.x, mouse.y);
|
||||
popupLongPressTimer.start();
|
||||
}
|
||||
}
|
||||
onReleased: mouse => {
|
||||
popupLongPressTimer.stop();
|
||||
const wasDragging = popupDragHandler.dragging;
|
||||
if (wasDragging)
|
||||
root.finishPopupDrag();
|
||||
|
||||
popupDragHandler.longPressing = false;
|
||||
popupDragHandler.dragging = false;
|
||||
popupDragHandler.dragAxisOffset = 0;
|
||||
}
|
||||
onPositionChanged: mouse => {
|
||||
const axisDelta = menuContainer.popupUsesVerticalLine ? (mouse.y - popupDragHandler.dragStartPos.y) : (mouse.x - popupDragHandler.dragStartPos.x);
|
||||
if (popupDragHandler.longPressing && !popupDragHandler.dragging && Math.abs(axisDelta) > 5) {
|
||||
popupDragHandler.dragging = true;
|
||||
root.beginPopupDrag(index);
|
||||
}
|
||||
if (!popupDragHandler.dragging)
|
||||
return;
|
||||
|
||||
popupDragHandler.dragAxisOffset = axisDelta;
|
||||
root.updatePopupDrag(axisDelta, index);
|
||||
}
|
||||
onClicked: mouse => {
|
||||
if (popupDragHandler.dragging)
|
||||
return;
|
||||
if (!trayItem)
|
||||
return;
|
||||
if (mouse.button === Qt.LeftButton && !trayItem.onlyMenu) {
|
||||
trayItem.activate();
|
||||
root.menuOpen = false;
|
||||
return;
|
||||
}
|
||||
if (!trayItem.hasMenu) {
|
||||
const gp = itemArea.mapToGlobal(mouse.x, mouse.y);
|
||||
root.callContextMenuFallback(trayItem.id, Math.round(gp.x), Math.round(gp.y));
|
||||
return;
|
||||
}
|
||||
root.showForTrayItem(trayItem, menuContainer, parentScreen, root.isAtBottom, root.isVerticalOrientation, root.axis);
|
||||
if (!trayItem.hasMenu) {
|
||||
const gp = itemArea.mapToGlobal(mouse.x, mouse.y);
|
||||
root.callContextMenuFallback(trayItem.id, Math.round(gp.x), Math.round(gp.y));
|
||||
return;
|
||||
}
|
||||
root.showForTrayItem(trayItem, menuContainer, parentScreen, root.isAtBottom, root.isVerticalOrientation, root.axis);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1723,13 +1555,11 @@ BasePill {
|
||||
anchorPos = Qt.point(targetX, targetY);
|
||||
}
|
||||
} else {
|
||||
// Window-local maps directly to screen-local because the bar window spans
|
||||
// the full screen edge; this avoids mixing mapToGlobal with a separately-
|
||||
// tracked screen.x/.y origin, which desync on non-primary monitors and after
|
||||
// DPMS/hotplug.
|
||||
const localPos = targetItem.mapToItem(null, 0, 0);
|
||||
const relativeX = localPos.x;
|
||||
const relativeY = localPos.y;
|
||||
const globalPos = targetItem.mapToGlobal(0, 0);
|
||||
const screenX = screen.x || 0;
|
||||
const screenY = screen.y || 0;
|
||||
const relativeX = globalPos.x - screenX;
|
||||
const relativeY = globalPos.y - screenY;
|
||||
|
||||
if (menuRoot.isVertical) {
|
||||
const edge = menuRoot.axis?.edge;
|
||||
@@ -1865,12 +1695,7 @@ BasePill {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
text: {
|
||||
const itemId = menuRoot.trayItem?.id || "Unknown";
|
||||
if (root.isAutoOverflowTrayItem(menuRoot.trayItem))
|
||||
return itemId + " · " + I18n.tr("Keep in Bar");
|
||||
return itemId;
|
||||
}
|
||||
text: menuRoot.trayItem?.id || "Unknown"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceTextMedium
|
||||
elide: Text.ElideMiddle
|
||||
@@ -1881,11 +1706,7 @@ BasePill {
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
name: {
|
||||
if (root.isAutoOverflowTrayItem(menuRoot.trayItem))
|
||||
return "push_pin";
|
||||
return root.isManualHiddenTrayItem(menuRoot.trayItem) ? "visibility" : "visibility_off";
|
||||
}
|
||||
name: SessionData.isHiddenTrayId(root.getTrayItemKey(menuRoot.trayItem)) ? "visibility" : "visibility_off"
|
||||
size: 16
|
||||
color: Theme.widgetTextColor
|
||||
}
|
||||
@@ -1899,9 +1720,7 @@ BasePill {
|
||||
const itemKey = root.getTrayItemKey(menuRoot.trayItem);
|
||||
if (!itemKey)
|
||||
return;
|
||||
if (root.isAutoOverflowTrayItem(menuRoot.trayItem)) {
|
||||
root.promoteTrayItemToBar(menuRoot.trayItem);
|
||||
} else if (root.isManualHiddenTrayItem(menuRoot.trayItem)) {
|
||||
if (SessionData.isHiddenTrayId(itemKey)) {
|
||||
SessionData.showTrayId(itemKey);
|
||||
} else {
|
||||
SessionData.hideTrayId(itemKey);
|
||||
|
||||
@@ -108,6 +108,9 @@ DankPopout {
|
||||
MprisController.setActivePlayer(player);
|
||||
root.__hideDropdowns();
|
||||
}
|
||||
onDeviceSelected: device => {
|
||||
root.__hideDropdowns();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -227,13 +230,6 @@ DankPopout {
|
||||
return;
|
||||
}
|
||||
|
||||
if (root.currentTabIndex === 0 && overviewLoader.item?.handleKeyEvent) {
|
||||
if (overviewLoader.item.handleKeyEvent(event)) {
|
||||
event.accepted = true;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (root.currentTabIndex === 1 && mediaLoader.item?.handleKeyEvent) {
|
||||
if (mediaLoader.item.handleKeyEvent(event)) {
|
||||
event.accepted = true;
|
||||
@@ -363,7 +359,6 @@ DankPopout {
|
||||
sourceComponent: Component {
|
||||
OverviewTab {
|
||||
onCloseDash: root.dashVisible = false
|
||||
onNavFocusRequested: mainContainer.forceActiveFocus()
|
||||
onSwitchToWeatherTab: {
|
||||
if (SettingsData.weatherEnabled) {
|
||||
root.currentTabIndex = 3;
|
||||
|
||||
@@ -383,27 +383,7 @@ Item {
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
||||
onPressed: mouse => {
|
||||
if (mouse.button === Qt.RightButton) {
|
||||
mouse.accepted = true;
|
||||
}
|
||||
}
|
||||
onWheel: wheelEvent => {
|
||||
if (SettingsData.audioDeviceScrollVolumeEnabled && wheelEvent.x >= deviceMouseArea.width / 2) {
|
||||
AudioService.handleNodeVolumeWheel(modelData, wheelEvent);
|
||||
} else {
|
||||
wheelEvent.accepted = false;
|
||||
}
|
||||
}
|
||||
onClicked: mouse => {
|
||||
if (mouse.button === Qt.RightButton) {
|
||||
if (modelData && modelData.audio) {
|
||||
SessionData.suppressOSDTemporarily();
|
||||
modelData.audio.muted = !modelData.audio.muted;
|
||||
}
|
||||
return;
|
||||
}
|
||||
onClicked: {
|
||||
if (modelData && modelData.name) {
|
||||
AudioService.setDefaultSinkByName(modelData.name);
|
||||
root.deviceSelected(modelData);
|
||||
|
||||
@@ -866,27 +866,7 @@ Item {
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
||||
onPressed: mouse => {
|
||||
if (mouse.button === Qt.RightButton) {
|
||||
mouse.accepted = true;
|
||||
}
|
||||
}
|
||||
onWheel: wheelEvent => {
|
||||
const delta = wheelEvent.angleDelta.y;
|
||||
if (delta !== 0) {
|
||||
AudioService.cycleAudioOutputDirection(delta < 0);
|
||||
wheelEvent.accepted = true;
|
||||
}
|
||||
}
|
||||
onClicked: mouse => {
|
||||
if (mouse.button === Qt.RightButton) {
|
||||
if (AudioService.sink?.audio) {
|
||||
SessionData.suppressOSDTemporarily();
|
||||
AudioService.sink.audio.muted = !AudioService.sink.audio.muted;
|
||||
}
|
||||
return;
|
||||
}
|
||||
onClicked: {
|
||||
if (devicesExpanded) {
|
||||
const sinks = AudioService.getAvailableSinks();
|
||||
if (sinks && sinks.length > 1) {
|
||||
|
||||
@@ -1,311 +0,0 @@
|
||||
import QtQuick
|
||||
import qs.Common
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
|
||||
Item {
|
||||
id: root
|
||||
|
||||
LayoutMirroring.enabled: I18n.isRtl
|
||||
LayoutMirroring.childrenInherit: true
|
||||
|
||||
property var eventData: null
|
||||
property bool canEdit: false
|
||||
|
||||
signal editRequested
|
||||
signal deleteRequested
|
||||
signal closeRequested
|
||||
|
||||
readonly property bool _descriptionIsHtml: /<[a-z][^>]*>/i.test((eventData && eventData.description) || "")
|
||||
|
||||
function _styleAnchors(html) {
|
||||
return html.replace(/<a\s([^>]*)>/gi, (m, attrs) => {
|
||||
const cleaned = attrs.replace(/style="[^"]*"/gi, "");
|
||||
return "<a style=\"text-decoration:none; color:" + Theme.primary + ";\" " + cleaned + ">";
|
||||
});
|
||||
}
|
||||
|
||||
function _inlineMarkdown(line) {
|
||||
let out = line.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">");
|
||||
out = out.replace(/\\([\\`*_{}[\]()#+\-.!~>])/g, "$1");
|
||||
out = out.replace(/(?:https?:\/\/|www\.)[^\s<>)\]]*[^\s<>)\].,;:!?"']/g, (m, offset, s) => {
|
||||
const prev = offset > 0 ? s[offset - 1] : "";
|
||||
if (prev === "(" || prev === "[" || prev === "\"" || prev === "'")
|
||||
return m;
|
||||
const href = m.startsWith("www.") ? "https://" + m : m;
|
||||
return "<a href=\"" + href + "\">" + m + "</a>";
|
||||
});
|
||||
out = out.replace(/\[([^\]]+)\]\(([^()\s]+)\)/g, "<a href=\"$2\">$1</a>");
|
||||
out = out.replace(/\*\*([^*]+)\*\*/g, "<b>$1</b>");
|
||||
out = out.replace(/(^|[^*])\*([^*\s][^*]*)\*/g, "$1<i>$2</i>");
|
||||
return out;
|
||||
}
|
||||
|
||||
// Descriptions arrive as HTML (Google) or markdown/plain text; both render
|
||||
// as RichText so links become clickable anchors recolored to the theme.
|
||||
function _descriptionRichText() {
|
||||
const raw = ((eventData && eventData.description) || "").trim();
|
||||
if (raw === "")
|
||||
return "";
|
||||
if (_descriptionIsHtml)
|
||||
return _styleAnchors(raw);
|
||||
|
||||
const parts = [];
|
||||
let list = "";
|
||||
const closeList = () => {
|
||||
if (list === "")
|
||||
return;
|
||||
parts.push("</" + list + ">");
|
||||
list = "";
|
||||
};
|
||||
|
||||
const lines = raw.split("\n");
|
||||
for (let i = 0; i < lines.length; i++) {
|
||||
const ul = lines[i].match(/^\s*[-*+]\s+(.+)$/);
|
||||
const ol = lines[i].match(/^\s*\d+[.)]\s+(.+)$/);
|
||||
if (ul || ol) {
|
||||
const tag = ul ? "ul" : "ol";
|
||||
if (list !== tag) {
|
||||
closeList();
|
||||
parts.push("<" + tag + ">");
|
||||
list = tag;
|
||||
}
|
||||
parts.push("<li>" + _inlineMarkdown((ul || ol)[1]) + "</li>");
|
||||
continue;
|
||||
}
|
||||
closeList();
|
||||
parts.push(_inlineMarkdown(lines[i]) + "<br/>");
|
||||
}
|
||||
closeList();
|
||||
return _styleAnchors(parts.join("").replace(/<br\/>$/, ""));
|
||||
}
|
||||
|
||||
function _timeText() {
|
||||
if (!eventData)
|
||||
return "";
|
||||
const dateStr = Qt.formatDate(eventData.start, "ddd, MMM d");
|
||||
if (eventData.allDay)
|
||||
return I18n.tr("All day") + " · " + dateStr;
|
||||
const fmt = SettingsData.use24HourClock ? "HH:mm" : "h:mm AP";
|
||||
const startStr = Qt.formatTime(eventData.start, fmt);
|
||||
if (eventData.start.getTime() === eventData.end.getTime())
|
||||
return dateStr + " · " + startStr;
|
||||
return dateStr + " · " + startStr + " – " + Qt.formatTime(eventData.end, fmt);
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
anchors.fill: parent
|
||||
radius: Theme.cornerRadius
|
||||
color: Qt.rgba(0, 0, 0, 0.45)
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
onClicked: root.closeRequested()
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
anchors.centerIn: parent
|
||||
width: Math.min(parent.width - Theme.spacingL * 2, 380)
|
||||
height: Math.min(parent.height - Theme.spacingM * 2, body.implicitHeight + Theme.spacingL * 2)
|
||||
radius: Theme.cornerRadius
|
||||
color: Theme.surfaceContainerHigh
|
||||
border.color: Theme.outlineMedium
|
||||
border.width: 1
|
||||
clip: true
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
id: closeButton
|
||||
anchors.top: parent.top
|
||||
anchors.right: parent.right
|
||||
anchors.margins: Theme.spacingXS
|
||||
circular: false
|
||||
iconName: "close"
|
||||
iconSize: 16
|
||||
z: 1
|
||||
onClicked: root.closeRequested()
|
||||
}
|
||||
|
||||
DankFlickable {
|
||||
anchors.fill: parent
|
||||
anchors.margins: Theme.spacingL
|
||||
anchors.topMargin: Theme.spacingL
|
||||
contentWidth: width
|
||||
contentHeight: body.implicitHeight
|
||||
clip: true
|
||||
|
||||
Column {
|
||||
id: body
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Rectangle {
|
||||
width: 4
|
||||
height: titleText.implicitHeight
|
||||
radius: 2
|
||||
anchors.top: parent.top
|
||||
color: (root.eventData && root.eventData.color) ? root.eventData.color : Theme.primary
|
||||
}
|
||||
|
||||
StyledText {
|
||||
id: titleText
|
||||
width: parent.width - 4 - Theme.spacingS - closeButton.width
|
||||
text: root.eventData ? root.eventData.title : ""
|
||||
font.pixelSize: Theme.fontSizeLarge
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
wrapMode: Text.Wrap
|
||||
maximumLineCount: 3
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: root._timeText()
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
wrapMode: Text.Wrap
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
visible: root.eventData && root.eventData.calendar
|
||||
|
||||
DankIcon {
|
||||
name: "calendar_month"
|
||||
size: 14
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.top: parent.top
|
||||
anchors.topMargin: 2
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width - 14 - Theme.spacingXS
|
||||
text: {
|
||||
if (!root.eventData)
|
||||
return "";
|
||||
const acc = root.eventData.account || "";
|
||||
return root.eventData.calendar + (acc ? " · " + acc : "");
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
wrapMode: Text.Wrap
|
||||
maximumLineCount: 2
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
visible: root.eventData && root.eventData.location
|
||||
|
||||
DankIcon {
|
||||
name: "place"
|
||||
size: 14
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.top: parent.top
|
||||
anchors.topMargin: 2
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width - 14 - Theme.spacingXS
|
||||
text: root.eventData ? root.eventData.location : ""
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
wrapMode: Text.Wrap
|
||||
maximumLineCount: 2
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
visible: root.eventData && root.eventData.url
|
||||
|
||||
DankIcon {
|
||||
name: "link"
|
||||
size: 14
|
||||
color: Theme.primary
|
||||
anchors.top: parent.top
|
||||
anchors.topMargin: 2
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width - 14 - Theme.spacingXS
|
||||
text: root.eventData ? root.eventData.url : ""
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.primary
|
||||
wrapMode: Text.WrapAnywhere
|
||||
maximumLineCount: 2
|
||||
elide: Text.ElideRight
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (root.eventData && root.eventData.url)
|
||||
Qt.openUrlExternally(root.eventData.url);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
id: descriptionText
|
||||
width: parent.width
|
||||
text: root._descriptionRichText()
|
||||
visible: root.eventData && root.eventData.description
|
||||
textFormat: Text.RichText
|
||||
linkColor: Theme.primary
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
wrapMode: Text.Wrap
|
||||
onLinkActivated: link => Qt.openUrlExternally(link)
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
acceptedButtons: Qt.NoButton
|
||||
cursorShape: descriptionText.hoveredLink !== "" ? Qt.PointingHandCursor : Qt.ArrowCursor
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
visible: root.canEdit
|
||||
topPadding: Theme.spacingXS
|
||||
|
||||
DankButton {
|
||||
text: I18n.tr("Edit")
|
||||
iconName: "edit"
|
||||
buttonHeight: 32
|
||||
onClicked: root.editRequested()
|
||||
}
|
||||
|
||||
DankButton {
|
||||
text: I18n.tr("Delete")
|
||||
iconName: "delete"
|
||||
buttonHeight: 32
|
||||
backgroundColor: Theme.withAlpha(Theme.error, 0.15)
|
||||
textColor: Theme.error
|
||||
onClicked: root.deleteRequested()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,350 +0,0 @@
|
||||
import QtQuick
|
||||
import qs.Common
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
|
||||
Item {
|
||||
id: root
|
||||
|
||||
LayoutMirroring.enabled: I18n.isRtl
|
||||
LayoutMirroring.childrenInherit: true
|
||||
|
||||
property var eventData: null
|
||||
property date initialDate: new Date()
|
||||
|
||||
signal saved
|
||||
signal closeRequested
|
||||
|
||||
property string fTitle: ""
|
||||
property bool fAllDay: false
|
||||
property date fDate: initialDate
|
||||
property string fStart: "10:00"
|
||||
property string fEnd: "11:00"
|
||||
property string fLocation: ""
|
||||
property string fDescription: ""
|
||||
property string fCalendarId: ""
|
||||
property int fReminder: -1
|
||||
property string errorText: ""
|
||||
property bool saving: false
|
||||
|
||||
readonly property var _cals: CalendarService.writableCalendars()
|
||||
readonly property var _remLabels: [I18n.tr("No reminder"), I18n.tr("At start"), I18n.tr("5 min before"), I18n.tr("10 min before"), I18n.tr("15 min before"), I18n.tr("30 min before"), I18n.tr("1 hour before"), I18n.tr("1 day before")]
|
||||
readonly property var _remMins: [-1, 0, 5, 10, 15, 30, 60, 1440]
|
||||
|
||||
function _parseTime(value) {
|
||||
const m = value.trim().match(/^(\d{1,2}):(\d{2})$/);
|
||||
if (!m)
|
||||
return null;
|
||||
const h = parseInt(m[1]);
|
||||
const min = parseInt(m[2]);
|
||||
if (h > 23 || min > 59)
|
||||
return null;
|
||||
return {
|
||||
"h": h,
|
||||
"m": min
|
||||
};
|
||||
}
|
||||
|
||||
function _isoFromDateTime(dateObj, h, m) {
|
||||
const d = new Date(dateObj);
|
||||
d.setHours(h, m, 0, 0);
|
||||
return d.toISOString();
|
||||
}
|
||||
|
||||
function _allDayIso(dateObj, dayOffset) {
|
||||
return new Date(Date.UTC(dateObj.getFullYear(), dateObj.getMonth(), dateObj.getDate() + dayOffset)).toISOString();
|
||||
}
|
||||
|
||||
function _calendarName(id) {
|
||||
for (let i = 0; i < _cals.length; i++) {
|
||||
if (_cals[i].id === id)
|
||||
return _cals[i].name;
|
||||
}
|
||||
return _cals.length > 0 ? _cals[0].name : "";
|
||||
}
|
||||
|
||||
function save() {
|
||||
const title = fTitle.trim();
|
||||
if (!title) {
|
||||
errorText = I18n.tr("Title is required");
|
||||
return;
|
||||
}
|
||||
let calId = fCalendarId;
|
||||
if (!calId) {
|
||||
const def = CalendarService.defaultCalendar();
|
||||
calId = def ? def.id : "";
|
||||
}
|
||||
if (!calId) {
|
||||
errorText = I18n.tr("No writable calendar available");
|
||||
return;
|
||||
}
|
||||
let startIso, endIso;
|
||||
if (fAllDay) {
|
||||
startIso = _allDayIso(fDate, 0);
|
||||
endIso = _allDayIso(fDate, 1);
|
||||
} else {
|
||||
const s = _parseTime(fStart);
|
||||
const e = _parseTime(fEnd);
|
||||
if (!s || !e) {
|
||||
errorText = I18n.tr("Use HH:MM time format");
|
||||
return;
|
||||
}
|
||||
startIso = _isoFromDateTime(fDate, s.h, s.m);
|
||||
endIso = _isoFromDateTime(fDate, e.h, e.m);
|
||||
if (new Date(endIso).getTime() <= new Date(startIso).getTime()) {
|
||||
errorText = I18n.tr("End must be after start");
|
||||
return;
|
||||
}
|
||||
}
|
||||
const fields = {
|
||||
"calendarId": calId,
|
||||
"summary": title,
|
||||
"description": fDescription,
|
||||
"location": fLocation,
|
||||
"start": startIso,
|
||||
"end": endIso,
|
||||
"allDay": fAllDay,
|
||||
"reminders": fReminder >= 0 ? [
|
||||
{
|
||||
"method": "popup",
|
||||
"minutes": fReminder
|
||||
}
|
||||
] : []
|
||||
};
|
||||
saving = true;
|
||||
errorText = "";
|
||||
const cb = response => {
|
||||
saving = false;
|
||||
if (response.error) {
|
||||
errorText = response.error;
|
||||
return;
|
||||
}
|
||||
root.saved();
|
||||
};
|
||||
if (eventData && eventData.id)
|
||||
CalendarService.updateEvent(eventData.id, fields, cb);
|
||||
else
|
||||
CalendarService.createEvent(fields, cb);
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
if (!eventData) {
|
||||
fCalendarId = CalendarService.defaultCalendar() ? CalendarService.defaultCalendar().id : "";
|
||||
return;
|
||||
}
|
||||
fTitle = eventData.title || "";
|
||||
fAllDay = !!eventData.allDay;
|
||||
fDate = eventData.start;
|
||||
const fmt = "HH:mm";
|
||||
fStart = Qt.formatTime(eventData.start, fmt);
|
||||
fEnd = Qt.formatTime(eventData.end, fmt);
|
||||
fLocation = eventData.location || "";
|
||||
fDescription = eventData.description || "";
|
||||
fCalendarId = eventData.calendarId || "";
|
||||
if (eventData.reminders && eventData.reminders.length > 0)
|
||||
fReminder = eventData.reminders[0].minutes;
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
anchors.fill: parent
|
||||
radius: Theme.cornerRadius
|
||||
color: Qt.rgba(0, 0, 0, 0.45)
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
onClicked: root.closeRequested()
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
anchors.centerIn: parent
|
||||
width: Math.min(parent.width - Theme.spacingL * 2, 400)
|
||||
height: Math.min(parent.height - Theme.spacingM, 300)
|
||||
radius: Theme.cornerRadius
|
||||
color: Theme.surfaceContainerHigh
|
||||
border.color: Theme.outlineMedium
|
||||
border.width: 1
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
}
|
||||
|
||||
DankFlickable {
|
||||
anchors.fill: parent
|
||||
anchors.margins: Theme.spacingM
|
||||
contentWidth: width
|
||||
contentHeight: form.implicitHeight
|
||||
clip: true
|
||||
|
||||
Column {
|
||||
id: form
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: root.eventData ? I18n.tr("Edit event") : I18n.tr("New event")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
}
|
||||
|
||||
DankTextField {
|
||||
width: parent.width
|
||||
labelText: I18n.tr("Title")
|
||||
leftIconName: "title"
|
||||
leftIconSize: Theme.iconSize - 6
|
||||
placeholderText: I18n.tr("Event title")
|
||||
text: root.fTitle
|
||||
onTextChanged: root.fTitle = text
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
width: parent.width
|
||||
text: I18n.tr("All day")
|
||||
checked: root.fAllDay
|
||||
onToggled: checked => root.fAllDay = checked
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
DankActionButton {
|
||||
circular: false
|
||||
iconName: "chevron_left"
|
||||
iconSize: 16
|
||||
onClicked: {
|
||||
let d = new Date(root.fDate);
|
||||
d.setDate(d.getDate() - 1);
|
||||
root.fDate = d;
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width - 72
|
||||
text: Qt.formatDate(root.fDate, "ddd, MMM d yyyy")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
horizontalAlignment: Text.AlignHCenter
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
height: 32
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
circular: false
|
||||
iconName: "chevron_right"
|
||||
iconSize: 16
|
||||
onClicked: {
|
||||
let d = new Date(root.fDate);
|
||||
d.setDate(d.getDate() + 1);
|
||||
root.fDate = d;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
visible: !root.fAllDay
|
||||
|
||||
DankTextField {
|
||||
width: (parent.width - Theme.spacingS) / 2
|
||||
labelText: I18n.tr("Start")
|
||||
leftIconName: "schedule"
|
||||
leftIconSize: Theme.iconSize - 6
|
||||
placeholderText: "HH:MM"
|
||||
text: root.fStart
|
||||
onTextChanged: root.fStart = text
|
||||
}
|
||||
|
||||
DankTextField {
|
||||
width: (parent.width - Theme.spacingS) / 2
|
||||
labelText: I18n.tr("End")
|
||||
placeholderText: "HH:MM"
|
||||
text: root.fEnd
|
||||
onTextChanged: root.fEnd = text
|
||||
}
|
||||
}
|
||||
|
||||
DankDropdown {
|
||||
width: parent.width
|
||||
text: I18n.tr("Calendar")
|
||||
options: root._cals.map(c => c.name)
|
||||
currentValue: root._calendarName(root.fCalendarId)
|
||||
onValueChanged: value => {
|
||||
for (let i = 0; i < root._cals.length; i++) {
|
||||
if (root._cals[i].name === value) {
|
||||
root.fCalendarId = root._cals[i].id;
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DankDropdown {
|
||||
width: parent.width
|
||||
text: I18n.tr("Reminder")
|
||||
options: root._remLabels
|
||||
currentValue: root._remLabels[Math.max(0, root._remMins.indexOf(root.fReminder))]
|
||||
onValueChanged: value => {
|
||||
const idx = root._remLabels.indexOf(value);
|
||||
if (idx >= 0)
|
||||
root.fReminder = root._remMins[idx];
|
||||
}
|
||||
}
|
||||
|
||||
DankTextField {
|
||||
width: parent.width
|
||||
labelText: I18n.tr("Location")
|
||||
leftIconName: "place"
|
||||
leftIconSize: Theme.iconSize - 6
|
||||
placeholderText: I18n.tr("Add location")
|
||||
text: root.fLocation
|
||||
onTextChanged: root.fLocation = text
|
||||
}
|
||||
|
||||
DankTextField {
|
||||
width: parent.width
|
||||
labelText: I18n.tr("Notes")
|
||||
leftIconName: "notes"
|
||||
leftIconSize: Theme.iconSize - 6
|
||||
placeholderText: I18n.tr("Add notes")
|
||||
text: root.fDescription
|
||||
onTextChanged: root.fDescription = text
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: root.errorText
|
||||
visible: root.errorText !== ""
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.error
|
||||
wrapMode: Text.WordWrap
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankButton {
|
||||
text: root.saving ? I18n.tr("Saving…") : I18n.tr("Save")
|
||||
iconName: "check"
|
||||
buttonHeight: 32
|
||||
backgroundColor: Theme.primary
|
||||
textColor: Theme.primaryText
|
||||
enabled: !root.saving
|
||||
onClicked: root.save()
|
||||
}
|
||||
|
||||
DankButton {
|
||||
text: I18n.tr("Cancel")
|
||||
buttonHeight: 32
|
||||
onClicked: root.closeRequested()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -8,21 +8,14 @@ Rectangle {
|
||||
id: root
|
||||
readonly property var log: Log.scoped("CalendarOverviewCard")
|
||||
|
||||
LayoutMirroring.enabled: I18n.isRtl
|
||||
LayoutMirroring.childrenInherit: true
|
||||
|
||||
implicitWidth: SettingsData.showWeekNumber ? 736 : 700
|
||||
|
||||
property bool showEventDetails: false
|
||||
property date selectedDate: systemClock.date
|
||||
property var selectedDateEvents: []
|
||||
property bool hasEvents: selectedDateEvents && selectedDateEvents.length > 0
|
||||
property var detailEvent: null
|
||||
property bool showEditor: false
|
||||
property var editorEvent: null
|
||||
|
||||
signal closeDash
|
||||
signal navFocusRequested
|
||||
|
||||
function weekStartQt() {
|
||||
if (SettingsData.firstDayOfWeek >= 7 || SettingsData.firstDayOfWeek < 0) {
|
||||
@@ -86,7 +79,7 @@ Rectangle {
|
||||
}
|
||||
|
||||
function updateSelectedDateEvents() {
|
||||
if (CalendarService && CalendarService.calendarAvailable) {
|
||||
if (CalendarService && CalendarService.khalAvailable) {
|
||||
const events = CalendarService.getEventsForDate(selectedDate);
|
||||
selectedDateEvents = events;
|
||||
} else {
|
||||
@@ -95,7 +88,7 @@ Rectangle {
|
||||
}
|
||||
|
||||
function loadEventsForMonth() {
|
||||
if (!CalendarService || !CalendarService.calendarAvailable) {
|
||||
if (!CalendarService || !CalendarService.khalAvailable) {
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -111,83 +104,11 @@ Rectangle {
|
||||
CalendarService.loadEvents(startDate, endDate);
|
||||
}
|
||||
|
||||
function goToToday() {
|
||||
const now = systemClock.date;
|
||||
calendarGrid.selectedDate = now;
|
||||
calendarGrid.displayDate = now;
|
||||
root.selectedDate = now;
|
||||
loadEventsForMonth();
|
||||
}
|
||||
|
||||
function moveSelection(days) {
|
||||
let d = new Date(calendarGrid.selectedDate);
|
||||
d.setDate(d.getDate() + days);
|
||||
calendarGrid.selectedDate = d;
|
||||
root.selectedDate = d;
|
||||
if (d.getMonth() !== calendarGrid.displayDate.getMonth() || d.getFullYear() !== calendarGrid.displayDate.getFullYear()) {
|
||||
calendarGrid.displayDate = d;
|
||||
loadEventsForMonth();
|
||||
}
|
||||
}
|
||||
|
||||
function shiftMonth(delta) {
|
||||
let d = new Date(calendarGrid.displayDate);
|
||||
d.setMonth(d.getMonth() + delta);
|
||||
calendarGrid.displayDate = d;
|
||||
loadEventsForMonth();
|
||||
}
|
||||
|
||||
function handleKeyEvent(event) {
|
||||
if (showEventDetails) {
|
||||
if (event.key === Qt.Key_Escape) {
|
||||
showEventDetails = false;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
switch (event.key) {
|
||||
case Qt.Key_Left:
|
||||
case Qt.Key_H:
|
||||
moveSelection(I18n.isRtl ? 1 : -1);
|
||||
return true;
|
||||
case Qt.Key_Right:
|
||||
case Qt.Key_L:
|
||||
moveSelection(I18n.isRtl ? -1 : 1);
|
||||
return true;
|
||||
case Qt.Key_Up:
|
||||
case Qt.Key_K:
|
||||
moveSelection(-7);
|
||||
return true;
|
||||
case Qt.Key_Down:
|
||||
case Qt.Key_J:
|
||||
moveSelection(7);
|
||||
return true;
|
||||
case Qt.Key_PageUp:
|
||||
shiftMonth(-1);
|
||||
return true;
|
||||
case Qt.Key_PageDown:
|
||||
shiftMonth(1);
|
||||
return true;
|
||||
case Qt.Key_T:
|
||||
goToToday();
|
||||
return true;
|
||||
case Qt.Key_Return:
|
||||
case Qt.Key_Enter:
|
||||
case Qt.Key_Space:
|
||||
root.selectedDate = calendarGrid.selectedDate;
|
||||
showEventDetails = true;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
onSelectedDateChanged: updateSelectedDateEvents()
|
||||
|
||||
onShowEventDetailsChanged: {
|
||||
if (showEventDetails) {
|
||||
taskInput.forceActiveFocus();
|
||||
} else {
|
||||
navFocusRequested();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -201,8 +122,8 @@ Rectangle {
|
||||
updateSelectedDateEvents();
|
||||
}
|
||||
|
||||
function onCalendarAvailableChanged() {
|
||||
if (CalendarService && CalendarService.calendarAvailable) {
|
||||
function onKhalAvailableChanged() {
|
||||
if (CalendarService && CalendarService.khalAvailable) {
|
||||
loadEventsForMonth();
|
||||
}
|
||||
updateSelectedDateEvents();
|
||||
@@ -222,55 +143,6 @@ Rectangle {
|
||||
anchors.margins: Theme.spacingM
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Rectangle {
|
||||
id: dankWarning
|
||||
width: parent.width
|
||||
visible: CalendarService && CalendarService.dankNeedsLaunch
|
||||
height: visible ? Math.max(28, warningRow.implicitHeight) + Theme.spacingS : 0
|
||||
radius: Theme.cornerRadius
|
||||
color: Qt.rgba(Theme.warning.r, Theme.warning.g, Theme.warning.b, 0.12)
|
||||
border.color: Qt.rgba(Theme.warning.r, Theme.warning.g, Theme.warning.b, 0.35)
|
||||
border.width: 1
|
||||
|
||||
Row {
|
||||
id: warningRow
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
anchors.leftMargin: Theme.spacingS
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "warning"
|
||||
size: 16
|
||||
color: Theme.warning
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width - 16 - Theme.spacingS - (launchButton.visible ? launchButton.width + Theme.spacingS : 0)
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
text: (CalendarService && CalendarService.dankBinaryExists) ? I18n.tr("DankCalendar isn't running") : I18n.tr("DankCalendar isn't installed")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
wrapMode: Text.Wrap
|
||||
}
|
||||
|
||||
DankButton {
|
||||
id: launchButton
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
visible: CalendarService && CalendarService.dankBinaryExists
|
||||
text: I18n.tr("Launch")
|
||||
buttonHeight: 26
|
||||
backgroundColor: Theme.primary
|
||||
textColor: Theme.primaryText
|
||||
onClicked: CalendarService.launchDankCalendar()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: 40
|
||||
@@ -301,40 +173,11 @@ Rectangle {
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 32
|
||||
height: 32
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
radius: Theme.cornerRadius
|
||||
visible: CalendarService && CalendarService.canCreateEvents
|
||||
color: addEventArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.12) : "transparent"
|
||||
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: "event"
|
||||
size: 16
|
||||
color: Theme.primary
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: addEventArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
root.editorEvent = null;
|
||||
root.showEditor = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.leftMargin: 32 + Theme.spacingS * 2
|
||||
anchors.rightMargin: (CalendarService && CalendarService.canCreateEvents) ? 32 + Theme.spacingS * 2 : Theme.spacingS
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
height: 40
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
text: {
|
||||
@@ -386,7 +229,7 @@ Rectangle {
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width - 84
|
||||
width: parent.width - 56
|
||||
height: 28
|
||||
text: calendarGrid.displayDate.toLocaleDateString(I18n.locale(), "MMMM yyyy")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
@@ -396,28 +239,6 @@ Rectangle {
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 28
|
||||
height: 28
|
||||
radius: Theme.cornerRadius
|
||||
color: todayArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.12) : "transparent"
|
||||
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: "today"
|
||||
size: 14
|
||||
color: Theme.primary
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: todayArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: root.goToToday()
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 28
|
||||
height: 28
|
||||
@@ -567,8 +388,6 @@ Rectangle {
|
||||
height: width
|
||||
color: isToday ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.12) : dayArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.08) : "transparent"
|
||||
radius: Theme.cornerRadius
|
||||
border.color: (isSelected && !isToday) ? Theme.primary : "transparent"
|
||||
border.width: (isSelected && !isToday) ? 1 : 0
|
||||
|
||||
StyledText {
|
||||
anchors.centerIn: parent
|
||||
@@ -578,31 +397,21 @@ Rectangle {
|
||||
font.weight: isToday ? Font.Medium : Font.Normal
|
||||
}
|
||||
|
||||
Row {
|
||||
Rectangle {
|
||||
anchors.bottom: parent.bottom
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
anchors.bottomMargin: 3
|
||||
spacing: 2
|
||||
visible: CalendarService && CalendarService.calendarAvailable && CalendarService.hasEventsForDate(dayDate)
|
||||
anchors.bottomMargin: 4
|
||||
width: 12
|
||||
height: 2
|
||||
radius: Theme.cornerRadius
|
||||
visible: CalendarService && CalendarService.khalAvailable && CalendarService.hasEventsForDate(dayDate)
|
||||
color: isToday ? Qt.lighter(Theme.primary, 1.3) : Theme.primary
|
||||
opacity: isToday ? 0.9 : 0.7
|
||||
|
||||
Repeater {
|
||||
model: {
|
||||
const evs = CalendarService.getEventsForDate(dayDate);
|
||||
const seen = [];
|
||||
for (let i = 0; i < evs.length && seen.length < 3; i++) {
|
||||
const c = (evs[i].color && evs[i].color.length) ? evs[i].color : "primary";
|
||||
if (seen.indexOf(c) === -1)
|
||||
seen.push(c);
|
||||
}
|
||||
return seen;
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 5
|
||||
height: 5
|
||||
radius: 2.5
|
||||
color: modelData === "primary" ? (isToday ? Qt.lighter(Theme.primary, 1.3) : Theme.primary) : modelData
|
||||
opacity: isToday ? 0.95 : 0.8
|
||||
Behavior on opacity {
|
||||
NumberAnimation {
|
||||
duration: Theme.shortDuration
|
||||
easing.type: Theme.standardEasing
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -614,7 +423,6 @@ Rectangle {
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
calendarGrid.selectedDate = dayDate;
|
||||
root.selectedDate = dayDate;
|
||||
root.showEventDetails = true;
|
||||
}
|
||||
@@ -814,15 +622,7 @@ Rectangle {
|
||||
}
|
||||
}
|
||||
|
||||
readonly property bool isTask: modelData && modelData.id && modelData.id.startsWith("task_")
|
||||
readonly property color accentColor: {
|
||||
if (isTask)
|
||||
return modelData.completed ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.4) : Theme.primary;
|
||||
return (modelData && modelData.color && modelData.color.length) ? modelData.color : Theme.primary;
|
||||
}
|
||||
readonly property color surfaceColor: isDragging ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.15) : (eventMouseArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.06) : Theme.nestedSurface)
|
||||
|
||||
color: surfaceColor
|
||||
color: isDragging ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.15) : (eventMouseArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.06) : Theme.nestedSurface)
|
||||
border.color: isDragging ? Theme.primary : (eventMouseArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.15) : Theme.outlineMedium)
|
||||
border.width: (isDragging || eventMouseArea.containsMouse) ? 1 : Theme.layerOutlineWidth
|
||||
|
||||
@@ -860,22 +660,15 @@ Rectangle {
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: accentClip
|
||||
width: 4
|
||||
clip: true
|
||||
anchors.top: parent.top
|
||||
anchors.bottom: parent.bottom
|
||||
Rectangle {
|
||||
width: 3
|
||||
height: parent.height - 6
|
||||
anchors.left: parent.left
|
||||
|
||||
Rectangle {
|
||||
width: taskItem.width
|
||||
height: taskItem.height
|
||||
radius: taskItem.radius
|
||||
color: taskItem.accentColor
|
||||
anchors.top: parent.top
|
||||
anchors.left: parent.left
|
||||
}
|
||||
anchors.leftMargin: 3
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
radius: Theme.cornerRadius
|
||||
color: (modelData && modelData.id && modelData.id.startsWith("task_")) ? (modelData.completed ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.4) : Theme.primary) : Theme.primary
|
||||
opacity: 0.8
|
||||
}
|
||||
|
||||
// Drag Handle
|
||||
@@ -974,7 +767,6 @@ Rectangle {
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: (modelData && modelData.id && modelData.id.startsWith("task_") && modelData.completed) ? Qt.rgba(Theme.surfaceText.r, Theme.surfaceText.g, Theme.surfaceText.b, 0.5) : Theme.surfaceText
|
||||
font.weight: Font.Medium
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
elide: Text.ElideRight
|
||||
maximumLineCount: 1
|
||||
}
|
||||
@@ -982,24 +774,21 @@ Rectangle {
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: {
|
||||
if (!modelData)
|
||||
return "";
|
||||
const cal = (modelData.calendar && modelData.calendar.length) ? " · " + modelData.calendar : "";
|
||||
if (modelData.allDay)
|
||||
return I18n.tr("All day", "calendar task with no specific time") + cal;
|
||||
if (modelData.start && modelData.end) {
|
||||
if (!modelData || modelData.allDay) {
|
||||
return I18n.tr("All day", "calendar task with no specific time");
|
||||
} else if (modelData.start && modelData.end) {
|
||||
const timeFormat = SettingsData.use24HourClock ? "HH:mm" : "h:mm AP";
|
||||
const startTime = Qt.formatTime(modelData.start, timeFormat);
|
||||
if (modelData.start.toDateString() !== modelData.end.toDateString() || modelData.start.getTime() !== modelData.end.getTime())
|
||||
return startTime + " – " + Qt.formatTime(modelData.end, timeFormat) + cal;
|
||||
return startTime + cal;
|
||||
if (modelData.start.toDateString() !== modelData.end.toDateString() || modelData.start.getTime() !== modelData.end.getTime()) {
|
||||
return startTime + " – " + Qt.formatTime(modelData.end, timeFormat);
|
||||
}
|
||||
return startTime;
|
||||
}
|
||||
return "";
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Qt.rgba(Theme.surfaceText.r, Theme.surfaceText.g, Theme.surfaceText.b, 0.7)
|
||||
font.weight: Font.Normal
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
visible: text !== "" && modelData && modelData.id && !modelData.id.startsWith("task_")
|
||||
}
|
||||
}
|
||||
@@ -1035,9 +824,8 @@ Rectangle {
|
||||
taskItem.isEditing = false;
|
||||
}
|
||||
|
||||
Keys.onEscapePressed: event => {
|
||||
Keys.onEscapePressed: {
|
||||
taskItem.isEditing = false;
|
||||
event.accepted = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1050,15 +838,18 @@ Rectangle {
|
||||
anchors.leftMargin: (modelData && modelData.id && modelData.id.startsWith("task_")) ? 32 : 6
|
||||
anchors.rightMargin: (modelData && modelData.id && modelData.id.startsWith("task_")) ? 64 : 0
|
||||
hoverEnabled: true
|
||||
cursorShape: modelData ? Qt.PointingHandCursor : Qt.ArrowCursor
|
||||
enabled: modelData && !taskItem.isEditing
|
||||
cursorShape: (modelData && (modelData.url || (modelData.id && modelData.id.startsWith("task_")))) ? Qt.PointingHandCursor : Qt.ArrowCursor
|
||||
enabled: modelData && (modelData.url !== "" || (modelData.id && modelData.id.startsWith("task_"))) && !taskItem.isEditing
|
||||
onClicked: {
|
||||
if (modelData && modelData.id && modelData.id.startsWith("task_")) {
|
||||
CalendarService.toggleTask(modelData.id);
|
||||
return;
|
||||
} else if (modelData && modelData.url && modelData.url !== "") {
|
||||
if (Qt.openUrlExternally(modelData.url) === false) {
|
||||
log.warn("Failed to open URL: " + modelData.url);
|
||||
} else {
|
||||
root.closeDash();
|
||||
}
|
||||
}
|
||||
if (modelData)
|
||||
root.detailEvent = modelData;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1162,7 +953,7 @@ Rectangle {
|
||||
Text {
|
||||
text: I18n.tr("Add a task...", "placeholder in the new-task input field")
|
||||
color: Qt.rgba(Theme.surfaceText.r, Theme.surfaceText.g, Theme.surfaceText.b, 0.4)
|
||||
visible: taskInput.text.length === 0
|
||||
visible: !taskInput.text && !taskInput.activeFocus
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
@@ -1174,52 +965,6 @@ Rectangle {
|
||||
text = "";
|
||||
}
|
||||
}
|
||||
|
||||
Keys.onEscapePressed: event => {
|
||||
root.showEventDetails = false;
|
||||
event.accepted = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Loader {
|
||||
anchors.fill: parent
|
||||
z: 1000
|
||||
active: root.detailEvent !== null
|
||||
|
||||
sourceComponent: CalendarEventDetail {
|
||||
eventData: root.detailEvent
|
||||
canEdit: CalendarService && CalendarService.canCreateEvents && root.detailEvent && !root.detailEvent.readOnly && !(root.detailEvent.id && root.detailEvent.id.startsWith("task_"))
|
||||
onCloseRequested: root.detailEvent = null
|
||||
onEditRequested: {
|
||||
root.editorEvent = root.detailEvent;
|
||||
root.detailEvent = null;
|
||||
root.showEditor = true;
|
||||
}
|
||||
onDeleteRequested: {
|
||||
if (root.detailEvent && root.detailEvent.id)
|
||||
CalendarService.deleteEvent(root.detailEvent.id, null);
|
||||
root.detailEvent = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Loader {
|
||||
anchors.fill: parent
|
||||
z: 1000
|
||||
active: root.showEditor
|
||||
|
||||
sourceComponent: CalendarEventEditor {
|
||||
eventData: root.editorEvent
|
||||
initialDate: root.selectedDate
|
||||
onCloseRequested: {
|
||||
root.showEditor = false;
|
||||
root.editorEvent = null;
|
||||
}
|
||||
onSaved: {
|
||||
root.showEditor = false;
|
||||
root.editorEvent = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -14,11 +14,6 @@ Item {
|
||||
signal switchToWeatherTab
|
||||
signal switchToMediaTab
|
||||
signal closeDash
|
||||
signal navFocusRequested
|
||||
|
||||
function handleKeyEvent(event) {
|
||||
return calendarCard.handleKeyEvent(event);
|
||||
}
|
||||
|
||||
Item {
|
||||
anchors.fill: parent
|
||||
@@ -59,14 +54,12 @@ Item {
|
||||
|
||||
// Calendar - bottom middle (wider and taller)
|
||||
CalendarOverviewCard {
|
||||
id: calendarCard
|
||||
x: parent.width * 0.2 - Theme.spacingM
|
||||
y: 100 + Theme.spacingM
|
||||
width: parent.width * 0.6
|
||||
height: 300
|
||||
|
||||
onCloseDash: root.closeDash()
|
||||
onNavFocusRequested: root.navFocusRequested()
|
||||
}
|
||||
|
||||
// Media - bottom right (narrow and taller)
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
import QtQuick
|
||||
import QtQuick.Layouts
|
||||
import Quickshell
|
||||
import Quickshell.Io
|
||||
import qs.Common
|
||||
@@ -22,71 +21,21 @@ Item {
|
||||
property var currentTab: NotepadStorageService.tabs.length > NotepadStorageService.currentTabIndex ? NotepadStorageService.tabs[NotepadStorageService.currentTabIndex] : null
|
||||
property bool showSettingsMenu: false
|
||||
property string pendingSaveContent: ""
|
||||
readonly property bool conflictBannerVisible: currentTab !== null && NotepadStorageService.conflictTabId === currentTab.id
|
||||
property var slideout: null
|
||||
property bool inPopout: false
|
||||
property bool surfaceVisible: slideout ? slideout.isVisible : true
|
||||
|
||||
signal hideRequested
|
||||
signal popoutRequested
|
||||
signal dockRequested
|
||||
signal previewRequested(string content)
|
||||
|
||||
function externalSync() {
|
||||
textEditor.syncFromDisk();
|
||||
}
|
||||
|
||||
function flushAutoSave() {
|
||||
textEditor.autoSaveToSession();
|
||||
}
|
||||
|
||||
Ref {
|
||||
service: NotepadStorageService
|
||||
}
|
||||
|
||||
// In connected frame mode the slideout sits on the Overlay layer
|
||||
onFileDialogOpenChanged: {
|
||||
if (slideout)
|
||||
slideout.suppressOverlayLayer = fileDialogOpen;
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: slideout
|
||||
enabled: slideout !== null
|
||||
function onAboutToHide() {
|
||||
textEditor.autoSaveToSession();
|
||||
}
|
||||
function onRevealed() {
|
||||
textEditor.syncFromDisk();
|
||||
}
|
||||
}
|
||||
|
||||
function showConflictBanner(diskContent) {
|
||||
if (!currentTab)
|
||||
return;
|
||||
NotepadStorageService.flagConflict(currentTab.id, diskContent);
|
||||
}
|
||||
|
||||
function resolveConflictKeepEdits() {
|
||||
if (!root.conflictBannerVisible)
|
||||
return;
|
||||
NotepadStorageService.clearConflict();
|
||||
if (currentTab && currentTab.filePath && !currentTab.isTemporary) {
|
||||
root.saveToFile("file://" + currentTab.filePath);
|
||||
}
|
||||
}
|
||||
|
||||
function resolveConflictReload() {
|
||||
if (!root.conflictBannerVisible)
|
||||
return;
|
||||
const diskContent = NotepadStorageService.conflictDiskContent;
|
||||
NotepadStorageService.clearConflict();
|
||||
textEditor.reloadFromDisk(diskContent);
|
||||
}
|
||||
|
||||
function dismissConflictBanner() {
|
||||
if (root.conflictBannerVisible)
|
||||
NotepadStorageService.clearConflict();
|
||||
}
|
||||
|
||||
function hasUnsavedChanges() {
|
||||
@@ -102,14 +51,10 @@ Item {
|
||||
}
|
||||
|
||||
function performCreateNewTab() {
|
||||
textEditor.commitLiveBuffer();
|
||||
NotepadStorageService.createNewTab();
|
||||
textEditor.applyingShared = true;
|
||||
textEditor.text = "";
|
||||
textEditor.lastSavedContent = "";
|
||||
textEditor.loadedTabId = -1;
|
||||
textEditor.contentLoaded = true;
|
||||
textEditor.applyingShared = false;
|
||||
textEditor.textArea.forceActiveFocus();
|
||||
}
|
||||
|
||||
@@ -141,6 +86,7 @@ Item {
|
||||
|
||||
NotepadStorageService.switchToTab(tabIndex);
|
||||
Qt.callLater(() => {
|
||||
textEditor.loadCurrentTabContent();
|
||||
if (currentTab) {
|
||||
root.currentFileName = currentTab.fileName || "";
|
||||
root.currentFileUrl = currentTab.fileUrl || "";
|
||||
@@ -154,7 +100,6 @@ Item {
|
||||
var content = textEditor.text;
|
||||
var filePath = fileUrl.toString().replace(/^file:\/\//, '');
|
||||
|
||||
textEditor.externalWatchPaused = true;
|
||||
saveFileView.path = "";
|
||||
pendingSaveContent = content;
|
||||
saveFileView.path = filePath;
|
||||
@@ -164,53 +109,6 @@ Item {
|
||||
});
|
||||
}
|
||||
|
||||
function saveExternalWithFreshnessCheck() {
|
||||
if (!currentTab || currentTab.isTemporary || !currentTab.filePath)
|
||||
return;
|
||||
const filePath = currentTab.filePath;
|
||||
loadFileView.path = "";
|
||||
loadFileView.path = filePath;
|
||||
|
||||
if (!loadFileView.waitForJob()) {
|
||||
saveToFile("file://" + filePath);
|
||||
return;
|
||||
}
|
||||
Qt.callLater(() => {
|
||||
if (!currentTab || currentTab.isTemporary || currentTab.filePath !== filePath)
|
||||
return;
|
||||
const diskContent = loadFileView.text();
|
||||
if (diskContent !== undefined && diskContent !== null && diskContent !== textEditor.text && diskContent !== textEditor.lastSavedContent) {
|
||||
root.showConflictBanner(diskContent);
|
||||
return;
|
||||
}
|
||||
saveToFile("file://" + filePath);
|
||||
});
|
||||
}
|
||||
|
||||
function autoSaveExternal() {
|
||||
if (!SettingsData.notepadAutoSave)
|
||||
return;
|
||||
if (!currentTab || currentTab.isTemporary || !currentTab.filePath)
|
||||
return;
|
||||
if (!textEditor.hasUnsavedChanges())
|
||||
return;
|
||||
const filePath = currentTab.filePath;
|
||||
loadFileView.path = "";
|
||||
loadFileView.path = filePath;
|
||||
if (!loadFileView.waitForJob())
|
||||
return;
|
||||
Qt.callLater(() => {
|
||||
if (!currentTab || currentTab.isTemporary || currentTab.filePath !== filePath)
|
||||
return;
|
||||
const diskContent = loadFileView.text();
|
||||
if (diskContent === undefined || diskContent === null)
|
||||
return;
|
||||
if (diskContent !== textEditor.lastSavedContent)
|
||||
return;
|
||||
saveToFile("file://" + filePath);
|
||||
});
|
||||
}
|
||||
|
||||
function loadFromFile(fileUrl) {
|
||||
if (hasUnsavedTemporaryContent()) {
|
||||
root.pendingFileUrl = fileUrl;
|
||||
@@ -248,155 +146,14 @@ Item {
|
||||
|
||||
root.currentFileName = fileName;
|
||||
root.currentFileUrl = fileUrl;
|
||||
textEditor.loadedTabId = currentTab.id;
|
||||
NotepadStorageService.clearSessionBuffer(currentTab.id);
|
||||
if (root.conflictBannerVisible)
|
||||
NotepadStorageService.clearConflict();
|
||||
textEditor.saveCurrentTabContent();
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: conflictBanner
|
||||
anchors.top: parent.top
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
height: root.conflictBannerVisible ? bannerRect.implicitHeight : 0
|
||||
visible: height > 0
|
||||
clip: true
|
||||
z: 5
|
||||
|
||||
Behavior on height {
|
||||
NumberAnimation {
|
||||
duration: Theme.shortDuration
|
||||
easing.type: Theme.standardEasing
|
||||
}
|
||||
}
|
||||
|
||||
StyledRect {
|
||||
id: bannerRect
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.top: parent.top
|
||||
implicitHeight: bannerLayout.implicitHeight + Theme.spacingM * 2
|
||||
radius: Theme.cornerRadius
|
||||
color: Theme.withAlpha(Theme.warning, 0.12)
|
||||
border.color: Theme.withAlpha(Theme.warning, 0.5)
|
||||
border.width: 1
|
||||
|
||||
ColumnLayout {
|
||||
id: bannerLayout
|
||||
anchors.fill: parent
|
||||
anchors.margins: Theme.spacingM
|
||||
spacing: Theme.spacingS
|
||||
|
||||
RowLayout {
|
||||
Layout.fillWidth: true
|
||||
spacing: Theme.spacingM
|
||||
|
||||
DankIcon {
|
||||
Layout.alignment: Qt.AlignVCenter
|
||||
name: "sync_problem"
|
||||
size: Theme.iconSize - 2
|
||||
color: Theme.warning
|
||||
}
|
||||
|
||||
StyledText {
|
||||
Layout.fillWidth: true
|
||||
Layout.alignment: Qt.AlignVCenter
|
||||
text: I18n.tr("File changed on disk")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
wrapMode: Text.NoWrap
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
Layout.alignment: Qt.AlignVCenter
|
||||
iconName: "close"
|
||||
iconSize: Theme.iconSizeSmall
|
||||
iconColor: Theme.surfaceText
|
||||
buttonSize: 28
|
||||
onClicked: root.dismissConflictBanner()
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
Layout.fillWidth: true
|
||||
Layout.preferredHeight: 32
|
||||
|
||||
Row {
|
||||
id: bannerActions
|
||||
anchors.right: parent.right
|
||||
spacing: Theme.spacingS
|
||||
|
||||
readonly property real available: parent.width
|
||||
|
||||
StyledRect {
|
||||
width: Math.min(keepText.implicitWidth + Theme.spacingM * 2, Math.max(104, (bannerActions.available - bannerActions.spacing) / 2))
|
||||
height: 32
|
||||
radius: Theme.cornerRadius
|
||||
color: "transparent"
|
||||
border.color: Theme.outlineMedium
|
||||
border.width: 1
|
||||
|
||||
StateLayer {
|
||||
anchors.fill: parent
|
||||
cornerRadius: parent.radius
|
||||
stateColor: Theme.surfaceText
|
||||
onClicked: root.resolveConflictKeepEdits()
|
||||
}
|
||||
|
||||
StyledText {
|
||||
id: keepText
|
||||
anchors.centerIn: parent
|
||||
width: parent.width - Theme.spacingM
|
||||
text: I18n.tr("Keep My Edits")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
horizontalAlignment: Text.AlignHCenter
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
}
|
||||
|
||||
StyledRect {
|
||||
width: Math.min(reloadText.implicitWidth + Theme.spacingM * 2, Math.max(116, (bannerActions.available - bannerActions.spacing) / 2))
|
||||
height: 32
|
||||
radius: Theme.cornerRadius
|
||||
color: Theme.primary
|
||||
|
||||
StateLayer {
|
||||
anchors.fill: parent
|
||||
cornerRadius: parent.radius
|
||||
stateColor: Theme.background
|
||||
onClicked: root.resolveConflictReload()
|
||||
}
|
||||
|
||||
StyledText {
|
||||
id: reloadText
|
||||
anchors.centerIn: parent
|
||||
width: parent.width - Theme.spacingM
|
||||
text: I18n.tr("Reload From Disk")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.background
|
||||
horizontalAlignment: Text.AlignHCenter
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.top: conflictBanner.bottom
|
||||
anchors.topMargin: root.conflictBannerVisible ? Theme.spacingM : 0
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.bottom: parent.bottom
|
||||
anchors.fill: parent
|
||||
spacing: Theme.spacingM
|
||||
|
||||
NotepadTabs {
|
||||
@@ -421,12 +178,11 @@ Item {
|
||||
id: textEditor
|
||||
width: parent.width
|
||||
height: parent.height - tabBar.height - Theme.spacingM * 2
|
||||
inPopout: root.inPopout
|
||||
surfaceVisible: root.surfaceVisible
|
||||
|
||||
onSaveRequested: {
|
||||
if (currentTab && !currentTab.isTemporary && currentTab.filePath) {
|
||||
root.saveExternalWithFreshnessCheck();
|
||||
var fileUrl = "file://" + currentTab.filePath;
|
||||
saveToFile(fileUrl);
|
||||
} else {
|
||||
root.fileDialogOpen = true;
|
||||
saveBrowserLoader.active = true;
|
||||
@@ -458,28 +214,12 @@ Item {
|
||||
|
||||
onEscapePressed: {
|
||||
textEditor.autoSaveToSession();
|
||||
if (showSettingsMenu) {
|
||||
showSettingsMenu = false;
|
||||
return;
|
||||
}
|
||||
if (!root.inPopout) {
|
||||
root.hideRequested();
|
||||
}
|
||||
root.hideRequested();
|
||||
}
|
||||
|
||||
onSettingsRequested: {
|
||||
showSettingsMenu = !showSettingsMenu;
|
||||
}
|
||||
|
||||
onPopoutRequested: root.popoutRequested()
|
||||
|
||||
onDockRequested: root.dockRequested()
|
||||
|
||||
onConflictDetected: diskContent => {
|
||||
root.showConflictBanner(diskContent);
|
||||
}
|
||||
|
||||
onAutoSaveRequested: root.autoSaveExternal()
|
||||
}
|
||||
}
|
||||
|
||||
@@ -502,24 +242,17 @@ Item {
|
||||
printErrors: true
|
||||
|
||||
onSaved: {
|
||||
if (currentTab && saveFileView.path) {
|
||||
if (currentTab && saveFileView.path && pendingSaveContent) {
|
||||
NotepadStorageService.updateTabMetadata(NotepadStorageService.currentTabIndex, {
|
||||
hasUnsavedChanges: false,
|
||||
lastSavedContent: pendingSaveContent
|
||||
});
|
||||
root.lastSavedFileContent = pendingSaveContent;
|
||||
textEditor.lastSavedContent = pendingSaveContent;
|
||||
textEditor.ignoreNextExternalChange = true;
|
||||
textEditor.commitLiveBuffer();
|
||||
if (root.conflictBannerVisible)
|
||||
NotepadStorageService.clearConflict();
|
||||
pendingSaveContent = "";
|
||||
}
|
||||
textEditor.externalWatchPaused = false;
|
||||
pendingSaveContent = "";
|
||||
}
|
||||
|
||||
onSaveFailed: error => {
|
||||
textEditor.externalWatchPaused = false;
|
||||
pendingSaveContent = "";
|
||||
}
|
||||
}
|
||||
@@ -565,7 +298,6 @@ Item {
|
||||
|
||||
root.currentFileName = fileName;
|
||||
root.currentFileUrl = fileUrl;
|
||||
textEditor.externalWatchPaused = true;
|
||||
|
||||
if (currentTab) {
|
||||
NotepadStorageService.saveTabAs(NotepadStorageService.currentTabIndex, cleanPath);
|
||||
@@ -611,7 +343,7 @@ Item {
|
||||
browserTitle: I18n.tr("Open Notepad File")
|
||||
browserIcon: "folder_open"
|
||||
browserType: "notepad_load"
|
||||
fileExtensions: ["*"]
|
||||
fileExtensions: ["*.txt", "*.md", "*.*"]
|
||||
allowStacking: true
|
||||
|
||||
onFileSelected: path => {
|
||||
@@ -644,7 +376,6 @@ Item {
|
||||
modalHeight: contentLoader.item ? contentLoader.item.implicitHeight + Theme.spacingM * 2 : 180
|
||||
shouldBeVisible: false
|
||||
allowStacking: true
|
||||
useOverlayLayer: true
|
||||
|
||||
onBackgroundClicked: {
|
||||
close();
|
||||
|
||||
@@ -1,137 +0,0 @@
|
||||
import QtQuick
|
||||
import Quickshell
|
||||
import qs.Common
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
import qs.Modules.Notepad
|
||||
|
||||
FloatingWindow {
|
||||
id: win
|
||||
|
||||
property alias shouldBeVisible: win.visible
|
||||
|
||||
function show() {
|
||||
visible = true;
|
||||
}
|
||||
|
||||
function hide() {
|
||||
visible = false;
|
||||
}
|
||||
|
||||
function toggle() {
|
||||
visible = !visible;
|
||||
}
|
||||
|
||||
title: I18n.tr("Notepad")
|
||||
minimumSize: Qt.size(360, 320)
|
||||
implicitWidth: 640
|
||||
implicitHeight: 760
|
||||
color: Theme.surfaceContainer
|
||||
visible: false
|
||||
|
||||
onVisibleChanged: {
|
||||
if (visible) {
|
||||
Qt.callLater(notepad.externalSync);
|
||||
} else {
|
||||
notepad.flushAutoSave();
|
||||
}
|
||||
}
|
||||
|
||||
// A compositor close (e.g. niri close-window)
|
||||
onClosed: win.visible = false
|
||||
|
||||
Item {
|
||||
anchors.fill: parent
|
||||
|
||||
Item {
|
||||
id: titleBar
|
||||
anchors.top: parent.top
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
height: 44
|
||||
z: 10
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
onPressed: windowControls.tryStartMove()
|
||||
onDoubleClicked: windowControls.tryToggleMaximize()
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
anchors.fill: parent
|
||||
color: Theme.surfaceContainerHigh
|
||||
opacity: 0.5
|
||||
}
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "edit_note"
|
||||
size: Theme.iconSize - 2
|
||||
color: Theme.primary
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Notepad")
|
||||
font.pixelSize: Theme.fontSizeLarge
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
DankActionButton {
|
||||
visible: windowControls.canMaximize
|
||||
circular: false
|
||||
iconName: win.maximized ? "fullscreen_exit" : "fullscreen"
|
||||
iconSize: Theme.iconSize - 4
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: windowControls.tryToggleMaximize()
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
circular: false
|
||||
iconName: "close"
|
||||
iconSize: Theme.iconSize - 4
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: win.hide()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Notepad {
|
||||
id: notepad
|
||||
anchors.top: titleBar.bottom
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.bottom: parent.bottom
|
||||
anchors.topMargin: Theme.spacingM
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.rightMargin: Theme.spacingM
|
||||
anchors.bottomMargin: Theme.spacingM
|
||||
inPopout: true
|
||||
surfaceVisible: win.visible
|
||||
onHideRequested: win.hide()
|
||||
onDockRequested: {
|
||||
win.hide();
|
||||
PopoutService.openNotepadSlideout();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
FloatingWindowControls {
|
||||
id: windowControls
|
||||
targetWindow: win
|
||||
}
|
||||
}
|
||||
@@ -10,7 +10,6 @@ Item {
|
||||
property var cachedFontFamilies: []
|
||||
property var cachedMonoFamilies: []
|
||||
property bool fontsEnumerated: false
|
||||
property bool shortcutsExpanded: false
|
||||
|
||||
signal settingsRequested
|
||||
signal findRequested
|
||||
@@ -63,23 +62,11 @@ Item {
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
visible: root.isVisible
|
||||
onClicked: root.settingsRequested()
|
||||
z: 50
|
||||
color: Qt.rgba(Theme.surface.r, Theme.surface.g, Theme.surface.b, 0.85)
|
||||
|
||||
WheelHandler {
|
||||
// Hold scroll so the editor beneath doesn't move while settings are open.
|
||||
onWheel: event => {
|
||||
event.accepted = true;
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
onClicked: root.settingsRequested()
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
@@ -87,8 +74,8 @@ Item {
|
||||
visible: root.isVisible
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
width: Math.min(360, root.width - Theme.spacingL * 2)
|
||||
height: Math.min(settingsColumn.implicitHeight + Theme.spacingXL * 2, root.height - Theme.spacingL * 2)
|
||||
width: 360
|
||||
height: settingsColumn.implicitHeight + Theme.spacingXL * 2
|
||||
radius: Theme.cornerRadius
|
||||
color: Qt.rgba(Theme.surfaceContainer.r, Theme.surfaceContainer.g, Theme.surfaceContainer.b, Theme.notepadTransparency)
|
||||
border.color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.08)
|
||||
@@ -106,459 +93,275 @@ Item {
|
||||
z: parent.z - 1
|
||||
}
|
||||
|
||||
DankFlickable {
|
||||
id: settingsFlickable
|
||||
anchors.fill: parent
|
||||
clip: true
|
||||
contentWidth: width
|
||||
contentHeight: settingsColumn.implicitHeight + Theme.spacingXL * 2
|
||||
Column {
|
||||
id: settingsColumn
|
||||
width: parent.width - Theme.spacingXL * 2
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
anchors.top: parent.top
|
||||
anchors.topMargin: Theme.spacingXL
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Column {
|
||||
id: settingsColumn
|
||||
x: Theme.spacingXL
|
||||
y: Theme.spacingXL
|
||||
width: settingsFlickable.width - Theme.spacingXL * 2
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 36
|
||||
color: "transparent"
|
||||
|
||||
StyledText {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingXS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
text: I18n.tr("Notepad Settings")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.2)
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Use Monospace Font")
|
||||
description: I18n.tr("Toggle fonts")
|
||||
checked: SettingsData.notepadUseMonospace
|
||||
onToggled: checked => {
|
||||
SettingsData.notepadUseMonospace = checked;
|
||||
}
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Show Line Numbers")
|
||||
description: I18n.tr("Display line numbers in editor")
|
||||
checked: SettingsData.notepadShowLineNumbers
|
||||
onToggled: checked => {
|
||||
SettingsData.notepadShowLineNumbers = checked;
|
||||
}
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Auto-save to disk")
|
||||
description: I18n.tr("Automatically save changes to opened files as you type")
|
||||
checked: SettingsData.notepadAutoSave
|
||||
onToggled: checked => {
|
||||
SettingsData.notepadAutoSave = checked;
|
||||
}
|
||||
}
|
||||
|
||||
StyledRect {
|
||||
width: parent.width
|
||||
height: 60
|
||||
radius: Theme.cornerRadius
|
||||
color: "transparent"
|
||||
|
||||
StateLayer {
|
||||
anchors.fill: parent
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
stateColor: Theme.primary
|
||||
cornerRadius: parent.radius
|
||||
onClicked: root.findRequested()
|
||||
}
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingM
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingM
|
||||
|
||||
DankIcon {
|
||||
name: "search"
|
||||
size: Theme.iconSize - 2
|
||||
color: Theme.primary
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Find in Text")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Open search bar to find text")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: visible ? (fontDropdown.height + Theme.spacingS) : 0
|
||||
color: "transparent"
|
||||
visible: !SettingsData.notepadUseMonospace
|
||||
|
||||
DankDropdown {
|
||||
id: fontDropdown
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Font Family")
|
||||
options: cachedFontFamilies
|
||||
currentValue: {
|
||||
if (!SettingsData.notepadFontFamily || SettingsData.notepadFontFamily === "")
|
||||
return I18n.tr("Default (Global)");
|
||||
else
|
||||
return SettingsData.notepadFontFamily;
|
||||
}
|
||||
enableFuzzySearch: true
|
||||
onValueChanged: value => {
|
||||
if (value && (value.startsWith("Default") || value === "Default (Global)")) {
|
||||
SettingsData.notepadFontFamily = "";
|
||||
} else {
|
||||
SettingsData.notepadFontFamily = value;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: fontSizeRow.height + Theme.spacingS
|
||||
color: "transparent"
|
||||
|
||||
Row {
|
||||
id: fontSizeRow
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Column {
|
||||
width: parent.width - fontSizeControls.width - Theme.spacingM
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Font Size")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: SettingsData.notepadFontSize + "px"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
width: parent.width
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
id: fontSizeControls
|
||||
spacing: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
|
||||
DankActionButton {
|
||||
buttonSize: 32
|
||||
iconName: "remove"
|
||||
iconSize: Theme.iconSizeSmall
|
||||
enabled: SettingsData.notepadFontSize > 8
|
||||
backgroundColor: Qt.rgba(Theme.surfaceVariant.r, Theme.surfaceVariant.g, Theme.surfaceVariant.b, 0.5)
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: {
|
||||
var newSize = Math.max(8, SettingsData.notepadFontSize - 1);
|
||||
SettingsData.notepadFontSize = newSize;
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 60
|
||||
height: 32
|
||||
radius: Theme.cornerRadius
|
||||
color: Qt.rgba(Theme.surfaceVariant.r, Theme.surfaceVariant.g, Theme.surfaceVariant.b, 0.3)
|
||||
border.color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.2)
|
||||
border.width: 1
|
||||
|
||||
StyledText {
|
||||
anchors.centerIn: parent
|
||||
text: SettingsData.notepadFontSize + "px"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
buttonSize: 32
|
||||
iconName: "add"
|
||||
iconSize: Theme.iconSizeSmall
|
||||
enabled: SettingsData.notepadFontSize < 48
|
||||
backgroundColor: Qt.rgba(Theme.surfaceVariant.r, Theme.surfaceVariant.g, Theme.surfaceVariant.b, 0.5)
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: {
|
||||
var newSize = Math.min(48, SettingsData.notepadFontSize + 1);
|
||||
SettingsData.notepadFontSize = newSize;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: transparencySliderColumn.height + Theme.spacingS
|
||||
color: "transparent"
|
||||
|
||||
Column {
|
||||
id: transparencySliderColumn
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Surface Opacity")
|
||||
description: I18n.tr("Override global transparency for Notepad")
|
||||
checked: SettingsData.notepadTransparencyOverride >= 0
|
||||
onToggled: checked => {
|
||||
if (checked) {
|
||||
SettingsData.notepadTransparencyOverride = SettingsData.notepadLastCustomTransparency;
|
||||
} else {
|
||||
SettingsData.notepadTransparencyOverride = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DankSlider {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
height: 24
|
||||
visible: SettingsData.notepadTransparencyOverride >= 0
|
||||
value: Math.round((SettingsData.notepadTransparencyOverride >= 0 ? SettingsData.notepadTransparencyOverride : SettingsData.popupTransparency) * 100)
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: ""
|
||||
showValue: true
|
||||
wheelEnabled: false
|
||||
onSliderValueChanged: newValue => {
|
||||
if (SettingsData.notepadTransparencyOverride >= 0) {
|
||||
SettingsData.notepadTransparencyOverride = newValue / 100;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: gapColumn.height + Theme.spacingS
|
||||
color: "transparent"
|
||||
|
||||
Column {
|
||||
id: gapColumn
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Default Mode")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
DankButtonGroup {
|
||||
model: [I18n.tr("Slideout"), I18n.tr("Popout")]
|
||||
size: "small"
|
||||
currentIndex: SettingsData.notepadDefaultMode === "popout" ? 1 : 0
|
||||
onSelectionChanged: (index, selected) => {
|
||||
if (!selected)
|
||||
return;
|
||||
SettingsData.notepadDefaultMode = index === 1 ? "popout" : "slideout";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
visible: SettingsData.notepadDefaultMode !== "popout"
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Open From")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
DankButtonGroup {
|
||||
model: [I18n.tr("Right"), I18n.tr("Left")]
|
||||
size: "small"
|
||||
currentIndex: SettingsData.notepadSlideoutSide === "left" ? 1 : 0
|
||||
onSelectionChanged: (index, selected) => {
|
||||
if (!selected)
|
||||
return;
|
||||
SettingsData.notepadSlideoutSide = index === 1 ? "left" : "right";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Auto Compositor Gaps")
|
||||
description: I18n.tr("Inset the Notepad from screen edges using the compositor's configured gaps")
|
||||
checked: SettingsData.notepadUseCompositorGap
|
||||
onToggled: checked => {
|
||||
SettingsData.notepadUseCompositorGap = checked;
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
visible: !SettingsData.notepadUseCompositorGap
|
||||
text: I18n.tr("Manual Gaps")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
DankSlider {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingXS
|
||||
width: parent.width - Theme.spacingXS * 2
|
||||
height: 24
|
||||
visible: !SettingsData.notepadUseCompositorGap
|
||||
value: SettingsData.notepadEdgeGap
|
||||
minimum: 0
|
||||
maximum: 64
|
||||
unit: "px"
|
||||
showValue: true
|
||||
wheelEnabled: false
|
||||
onSliderValueChanged: newValue => {
|
||||
SettingsData.notepadEdgeGap = newValue;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 36
|
||||
color: "transparent"
|
||||
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: SettingsData.notepadUseMonospace ? I18n.tr("Using global monospace font from Settings → Personalization") : I18n.tr("Global fonts can be configured in Settings → Personalization")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceTextMedium
|
||||
wrapMode: Text.WordWrap
|
||||
opacity: 0.8
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingXS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
text: I18n.tr("Notepad Font Settings")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.2)
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Use Monospace Font")
|
||||
description: I18n.tr("Toggle fonts")
|
||||
checked: SettingsData.notepadUseMonospace
|
||||
onToggled: checked => {
|
||||
SettingsData.notepadUseMonospace = checked;
|
||||
}
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Show Line Numbers")
|
||||
description: I18n.tr("Display line numbers in editor")
|
||||
checked: SettingsData.notepadShowLineNumbers
|
||||
onToggled: checked => {
|
||||
SettingsData.notepadShowLineNumbers = checked;
|
||||
}
|
||||
}
|
||||
|
||||
StyledRect {
|
||||
width: parent.width
|
||||
height: 60
|
||||
radius: Theme.cornerRadius
|
||||
color: "transparent"
|
||||
|
||||
StateLayer {
|
||||
anchors.fill: parent
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
stateColor: Theme.primary
|
||||
cornerRadius: parent.radius
|
||||
onClicked: root.findRequested()
|
||||
}
|
||||
|
||||
StyledRect {
|
||||
width: parent.width
|
||||
implicitHeight: shortcutsHeader.height + (root.shortcutsExpanded ? shortcutsColumn.implicitHeight + Theme.spacingM : 0)
|
||||
radius: Theme.cornerRadius
|
||||
color: root.shortcutsExpanded ? Qt.rgba(Theme.surfaceContainer.r, Theme.surfaceContainer.g, Theme.surfaceContainer.b, 0.95) : "transparent"
|
||||
border.color: root.shortcutsExpanded ? Theme.primary : Theme.outlineMedium
|
||||
border.width: root.shortcutsExpanded ? 2 : 1
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingM
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingM
|
||||
|
||||
StateLayer {
|
||||
anchors.fill: parent
|
||||
stateColor: Theme.primary
|
||||
cornerRadius: parent.radius
|
||||
onClicked: root.shortcutsExpanded = !root.shortcutsExpanded
|
||||
}
|
||||
|
||||
Row {
|
||||
id: shortcutsHeader
|
||||
anchors.top: parent.top
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
height: 36
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: root.shortcutsExpanded ? "expand_less" : "expand_more"
|
||||
size: Theme.iconSizeSmall
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Keyboard Shortcuts")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
DankIcon {
|
||||
name: "search"
|
||||
size: Theme.iconSize - 2
|
||||
color: Theme.primary
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Column {
|
||||
id: shortcutsColumn
|
||||
visible: root.shortcutsExpanded
|
||||
width: parent.width - Theme.spacingL * 2
|
||||
anchors.top: shortcutsHeader.bottom
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
spacing: 2
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: I18n.tr("Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
text: I18n.tr("Find in Text")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
wrapMode: Text.WordWrap
|
||||
horizontalAlignment: Text.AlignHCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: I18n.tr("Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close")
|
||||
text: I18n.tr("Open search bar to find text")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
wrapMode: Text.WordWrap
|
||||
horizontalAlignment: Text.AlignHCenter
|
||||
color: Theme.surfaceVariantText
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: visible ? (fontDropdown.height + Theme.spacingS) : 0
|
||||
color: "transparent"
|
||||
visible: !SettingsData.notepadUseMonospace
|
||||
|
||||
DankDropdown {
|
||||
id: fontDropdown
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Font Family")
|
||||
options: cachedFontFamilies
|
||||
currentValue: {
|
||||
if (!SettingsData.notepadFontFamily || SettingsData.notepadFontFamily === "")
|
||||
return I18n.tr("Default (Global)");
|
||||
else
|
||||
return SettingsData.notepadFontFamily;
|
||||
}
|
||||
enableFuzzySearch: true
|
||||
onValueChanged: value => {
|
||||
if (value && (value.startsWith("Default") || value === "Default (Global)")) {
|
||||
SettingsData.notepadFontFamily = "";
|
||||
} else {
|
||||
SettingsData.notepadFontFamily = value;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: fontSizeRow.height + Theme.spacingS
|
||||
color: "transparent"
|
||||
|
||||
Row {
|
||||
id: fontSizeRow
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Column {
|
||||
width: parent.width - fontSizeControls.width - Theme.spacingM
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Font Size")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: SettingsData.notepadFontSize + "px"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
width: parent.width
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
id: fontSizeControls
|
||||
spacing: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
|
||||
DankActionButton {
|
||||
buttonSize: 32
|
||||
iconName: "remove"
|
||||
iconSize: Theme.iconSizeSmall
|
||||
enabled: SettingsData.notepadFontSize > 8
|
||||
backgroundColor: Qt.rgba(Theme.surfaceVariant.r, Theme.surfaceVariant.g, Theme.surfaceVariant.b, 0.5)
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: {
|
||||
var newSize = Math.max(8, SettingsData.notepadFontSize - 1);
|
||||
SettingsData.notepadFontSize = newSize;
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 60
|
||||
height: 32
|
||||
radius: Theme.cornerRadius
|
||||
color: Qt.rgba(Theme.surfaceVariant.r, Theme.surfaceVariant.g, Theme.surfaceVariant.b, 0.3)
|
||||
border.color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.2)
|
||||
border.width: 1
|
||||
|
||||
StyledText {
|
||||
anchors.centerIn: parent
|
||||
text: SettingsData.notepadFontSize + "px"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
buttonSize: 32
|
||||
iconName: "add"
|
||||
iconSize: Theme.iconSizeSmall
|
||||
enabled: SettingsData.notepadFontSize < 48
|
||||
backgroundColor: Qt.rgba(Theme.surfaceVariant.r, Theme.surfaceVariant.g, Theme.surfaceVariant.b, 0.5)
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: {
|
||||
var newSize = Math.min(48, SettingsData.notepadFontSize + 1);
|
||||
SettingsData.notepadFontSize = newSize;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: transparencySliderColumn.height + Theme.spacingS
|
||||
color: "transparent"
|
||||
|
||||
Column {
|
||||
id: transparencySliderColumn
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankToggle {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
text: I18n.tr("Custom Transparency")
|
||||
description: I18n.tr("Override global transparency for Notepad")
|
||||
checked: SettingsData.notepadTransparencyOverride >= 0
|
||||
onToggled: checked => {
|
||||
if (checked) {
|
||||
SettingsData.notepadTransparencyOverride = SettingsData.notepadLastCustomTransparency;
|
||||
} else {
|
||||
SettingsData.notepadTransparencyOverride = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DankSlider {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: -Theme.spacingM
|
||||
width: parent.width + Theme.spacingM
|
||||
height: 24
|
||||
visible: SettingsData.notepadTransparencyOverride >= 0
|
||||
value: Math.round((SettingsData.notepadTransparencyOverride >= 0 ? SettingsData.notepadTransparencyOverride : SettingsData.popupTransparency) * 100)
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: ""
|
||||
showValue: true
|
||||
wheelEnabled: false
|
||||
onSliderValueChanged: newValue => {
|
||||
if (SettingsData.notepadTransparencyOverride >= 0) {
|
||||
SettingsData.notepadTransparencyOverride = newValue / 100;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: parent.width
|
||||
text: SettingsData.notepadUseMonospace ? I18n.tr("Using global monospace font from Settings → Personalization") : I18n.tr("Global fonts can be configured in Settings → Personalization")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceTextMedium
|
||||
wrapMode: Text.WordWrap
|
||||
opacity: 0.8
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -32,23 +32,6 @@ Column {
|
||||
property string pluginHighlightedHtml: ""
|
||||
property string lastPluginContent: ""
|
||||
property int loadRequestId: 0
|
||||
property bool ignoreNextExternalChange: false
|
||||
property bool watcherReloadPending: false
|
||||
property bool externalWatchPaused: false
|
||||
property bool inPopout: false
|
||||
property bool surfaceVisible: true
|
||||
// Tab ids are Date.now() timestamps (~1.78e12) which overflow a 32-bit `int`,
|
||||
// corrupting the value (e.g. -946062153) and breaking buffer keying. `var`
|
||||
// holds the full JS-safe integer.
|
||||
property var loadedTabId: -1
|
||||
property bool applyingShared: false
|
||||
property bool showPathInfo: false
|
||||
|
||||
function currentFilePath() {
|
||||
if (!currentTab)
|
||||
return "";
|
||||
return currentTab.isTemporary ? (NotepadStorageService.baseDir + "/" + currentTab.filePath) : currentTab.filePath;
|
||||
}
|
||||
|
||||
signal saveRequested
|
||||
signal openRequested
|
||||
@@ -57,10 +40,6 @@ Column {
|
||||
signal escapePressed
|
||||
signal contentChanged
|
||||
signal settingsRequested
|
||||
signal popoutRequested
|
||||
signal dockRequested
|
||||
signal conflictDetected(string diskContent)
|
||||
signal autoSaveRequested
|
||||
|
||||
function hasUnsavedChanges() {
|
||||
if (!currentTab || !contentLoaded) {
|
||||
@@ -73,12 +52,6 @@ Column {
|
||||
return textArea.text !== lastSavedContent;
|
||||
}
|
||||
|
||||
function commitLiveBuffer() {
|
||||
if (loadedTabId < 0 || !contentLoaded)
|
||||
return;
|
||||
NotepadStorageService.setSessionBuffer(loadedTabId, textArea.text, lastSavedContent);
|
||||
}
|
||||
|
||||
function loadCurrentTabContent() {
|
||||
if (!currentTab)
|
||||
return;
|
||||
@@ -89,25 +62,8 @@ Column {
|
||||
const activeTab = NotepadStorageService.tabs.length > NotepadStorageService.currentTabIndex ? NotepadStorageService.tabs[NotepadStorageService.currentTabIndex] : null;
|
||||
if (requestId !== loadRequestId || !activeTab || activeTab.id !== requestedTabId)
|
||||
return;
|
||||
|
||||
const buffer = NotepadStorageService.getSessionBuffer(requestedTabId);
|
||||
if (buffer !== undefined) {
|
||||
applyingShared = true;
|
||||
lastSavedContent = buffer.baseline;
|
||||
textArea.text = buffer.content;
|
||||
applyingShared = false;
|
||||
loadedTabId = requestedTabId;
|
||||
contentLoaded = true;
|
||||
syncContentToPlugin();
|
||||
applyDiskContent(content);
|
||||
return;
|
||||
}
|
||||
|
||||
applyingShared = true;
|
||||
lastSavedContent = content;
|
||||
textArea.text = content;
|
||||
applyingShared = false;
|
||||
loadedTabId = requestedTabId;
|
||||
contentLoaded = true;
|
||||
syncContentToPlugin();
|
||||
});
|
||||
@@ -116,56 +72,14 @@ Column {
|
||||
function saveCurrentTabContent() {
|
||||
if (!currentTab || !contentLoaded)
|
||||
return;
|
||||
if (!currentTab.isTemporary)
|
||||
return;
|
||||
NotepadStorageService.saveTabContent(NotepadStorageService.currentTabIndex, textArea.text);
|
||||
lastSavedContent = textArea.text;
|
||||
NotepadStorageService.clearSessionBuffer(loadedTabId);
|
||||
}
|
||||
|
||||
function autoSaveToSession() {
|
||||
commitLiveBuffer();
|
||||
if (!currentTab || !contentLoaded)
|
||||
return;
|
||||
if (currentTab.isTemporary) {
|
||||
saveCurrentTabContent();
|
||||
} else if (SettingsData.notepadAutoSave) {
|
||||
root.autoSaveRequested();
|
||||
}
|
||||
}
|
||||
|
||||
function syncFromDisk() {
|
||||
if (!currentTab)
|
||||
return;
|
||||
loadCurrentTabContent();
|
||||
}
|
||||
|
||||
function applyDiskContent(diskContent) {
|
||||
if (diskContent === undefined || diskContent === null)
|
||||
return;
|
||||
if (diskContent === textArea.text) {
|
||||
lastSavedContent = diskContent;
|
||||
return;
|
||||
}
|
||||
if (diskContent === lastSavedContent) {
|
||||
return;
|
||||
}
|
||||
if (textArea.text === lastSavedContent) {
|
||||
reloadFromDisk(diskContent);
|
||||
} else if (surfaceVisible) {
|
||||
conflictDetected(diskContent);
|
||||
}
|
||||
}
|
||||
|
||||
function reloadFromDisk(diskContent) {
|
||||
applyingShared = true;
|
||||
contentLoaded = false;
|
||||
textArea.text = diskContent;
|
||||
lastSavedContent = diskContent;
|
||||
contentLoaded = true;
|
||||
applyingShared = false;
|
||||
NotepadStorageService.clearSessionBuffer(loadedTabId);
|
||||
syncContentToPlugin();
|
||||
saveCurrentTabContent();
|
||||
}
|
||||
|
||||
function setTextDocumentLineHeight() {
|
||||
@@ -288,8 +202,7 @@ Column {
|
||||
if (!currentTab)
|
||||
return;
|
||||
const filePath = currentTab?.filePath || "";
|
||||
const baseName = filePath.split('/').pop();
|
||||
const ext = baseName.includes('.') ? baseName.split('.').pop().toLowerCase() : "";
|
||||
const ext = filePath.split('.').pop().toLowerCase();
|
||||
const content = textArea.text;
|
||||
|
||||
if (content === lastPluginContent && SettingsData.getBuiltInPluginSetting("dankNotepadModule", "previewActive", false) === inlinePreviewVisible) {
|
||||
@@ -637,7 +550,6 @@ Column {
|
||||
Connections {
|
||||
target: NotepadStorageService
|
||||
function onCurrentTabIndexChanged() {
|
||||
root.commitLiveBuffer();
|
||||
loadCurrentTabContent();
|
||||
Qt.callLater(() => {
|
||||
textArea.forceActiveFocus();
|
||||
@@ -658,9 +570,7 @@ Column {
|
||||
}
|
||||
|
||||
onTextChanged: {
|
||||
// Debounced flush to the shared buffer (+ optional disk
|
||||
// autosave) for every loaded tab, not just scratch notes.
|
||||
if (contentLoaded && !applyingShared) {
|
||||
if (contentLoaded && text !== lastSavedContent) {
|
||||
autoSaveTimer.restart();
|
||||
}
|
||||
root.contentChanged();
|
||||
@@ -834,7 +744,6 @@ Column {
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Item {
|
||||
id: buttonBarItem
|
||||
width: parent.width
|
||||
height: 32
|
||||
|
||||
@@ -911,98 +820,17 @@ Column {
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
id: rightButtonRow
|
||||
DankActionButton {
|
||||
anchors.right: parent.right
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankActionButton {
|
||||
visible: !root.inPopout
|
||||
iconName: "open_in_new"
|
||||
iconSize: Theme.iconSize - 2
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: root.popoutRequested()
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
visible: root.inPopout
|
||||
iconName: "dock_to_right"
|
||||
iconSize: Theme.iconSize - 2
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: root.dockRequested()
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
iconName: "more_horiz"
|
||||
iconSize: Theme.iconSize - 2
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: root.settingsRequested()
|
||||
}
|
||||
}
|
||||
|
||||
StyledRect {
|
||||
id: pathInfoPopup
|
||||
visible: root.showPathInfo
|
||||
anchors.right: parent.right
|
||||
anchors.bottom: parent.top
|
||||
anchors.bottomMargin: Theme.spacingS
|
||||
width: Math.min(root.width, 360)
|
||||
height: pathInfoRow.implicitHeight + Theme.spacingS * 2
|
||||
radius: Theme.cornerRadius
|
||||
color: Theme.withAlpha(Theme.surfaceContainerHigh, Theme.popupTransparency)
|
||||
border.color: Theme.outlineMedium
|
||||
border.width: 1
|
||||
z: 10
|
||||
|
||||
Row {
|
||||
id: pathInfoRow
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.rightMargin: Theme.spacingM
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: currentTab && currentTab.isTemporary ? "draft" : "description"
|
||||
size: Theme.iconSize - 4
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
width: pathInfoRow.width - (Theme.iconSize - 4) - copyPathButton.width - Theme.spacingS * 2
|
||||
text: root.currentFilePath()
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
elide: Text.ElideMiddle
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
id: copyPathButton
|
||||
iconName: "content_copy"
|
||||
iconSize: Theme.iconSize - 6
|
||||
iconColor: Theme.surfaceTextMedium
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
onClicked: {
|
||||
const proc = clipboardCopyProcComp.createObject(root, {
|
||||
content: root.currentFilePath(),
|
||||
running: true
|
||||
});
|
||||
proc.exited.connect(() => {
|
||||
ToastService.showInfo(I18n.tr("Path copied to clipboard"));
|
||||
proc.destroy();
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
iconName: "more_horiz"
|
||||
iconSize: Theme.iconSize - 2
|
||||
iconColor: Theme.surfaceText
|
||||
onClicked: root.settingsRequested()
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
id: statusRow
|
||||
width: parent.width
|
||||
spacing: Theme.spacingL
|
||||
|
||||
@@ -1025,46 +853,35 @@ Column {
|
||||
opacity: 1.0
|
||||
}
|
||||
|
||||
Row {
|
||||
visible: textArea.text.length > 0
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
readonly property bool savingToDisk: autoSaveTimer.running && currentTab && (currentTab.isTemporary || SettingsData.notepadAutoSave)
|
||||
text: {
|
||||
if (savingToDisk) {
|
||||
return I18n.tr("Saving...");
|
||||
}
|
||||
|
||||
if (currentTab && currentTab.isTemporary) {
|
||||
return I18n.tr("Auto saved");
|
||||
}
|
||||
|
||||
return hasUnsavedChanges() ? I18n.tr("Unsaved changes") : I18n.tr("Saved");
|
||||
StyledText {
|
||||
text: {
|
||||
if (autoSaveTimer.running) {
|
||||
return I18n.tr("Auto-saving...");
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: {
|
||||
if (savingToDisk) {
|
||||
return Theme.primary;
|
||||
}
|
||||
|
||||
if (hasUnsavedChanges()) {
|
||||
if (currentTab && currentTab.isTemporary) {
|
||||
return Theme.success;
|
||||
return I18n.tr("Unsaved note...");
|
||||
} else {
|
||||
return I18n.tr("Unsaved changes");
|
||||
}
|
||||
|
||||
return hasUnsavedChanges() ? Theme.warning : Theme.success;
|
||||
} else {
|
||||
return I18n.tr("Saved");
|
||||
}
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: {
|
||||
if (autoSaveTimer.running) {
|
||||
return Theme.primary;
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
iconName: "info"
|
||||
iconSize: Theme.iconSizeSmall
|
||||
iconColor: root.showPathInfo ? Theme.primary : Theme.surfaceTextMedium
|
||||
buttonSize: 20
|
||||
onClicked: root.showPathInfo = !root.showPathInfo
|
||||
if (hasUnsavedChanges()) {
|
||||
return Theme.warning;
|
||||
} else {
|
||||
return Theme.success;
|
||||
}
|
||||
}
|
||||
opacity: textArea.text.length > 0 ? 1.0 : 0.0
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1085,38 +902,6 @@ Column {
|
||||
onTriggered: syncContentToPlugin()
|
||||
}
|
||||
|
||||
FileView {
|
||||
id: externalWatch
|
||||
path: (!root.externalWatchPaused && currentTab && !currentTab.isTemporary && currentTab.filePath) ? currentTab.filePath : ""
|
||||
blockLoading: true
|
||||
preload: true
|
||||
watchChanges: true
|
||||
|
||||
onFileChanged: {
|
||||
root.watcherReloadPending = true;
|
||||
reload();
|
||||
}
|
||||
|
||||
onLoaded: {
|
||||
if (root.ignoreNextExternalChange) {
|
||||
root.ignoreNextExternalChange = false;
|
||||
root.lastSavedContent = externalWatch.text();
|
||||
root.watcherReloadPending = false;
|
||||
return;
|
||||
}
|
||||
if (!root.watcherReloadPending)
|
||||
return;
|
||||
root.watcherReloadPending = false;
|
||||
if (!root.contentLoaded || !root.currentTab || root.currentTab.isTemporary)
|
||||
return;
|
||||
if (!root.surfaceVisible)
|
||||
return;
|
||||
root.applyDiskContent(externalWatch.text());
|
||||
}
|
||||
|
||||
onLoadFailed: error => {}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: SettingsData
|
||||
function onBuiltInPluginSettingsChanged() {
|
||||
@@ -1125,24 +910,4 @@ Column {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: NotepadStorageService
|
||||
function onSessionBufferRevisionChanged() {
|
||||
if (applyingShared || !contentLoaded || loadedTabId < 0)
|
||||
return;
|
||||
if (textArea.activeFocus)
|
||||
return;
|
||||
var buffer = NotepadStorageService.getSessionBuffer(loadedTabId);
|
||||
if (buffer === undefined || buffer.content === textArea.text)
|
||||
return;
|
||||
if (textArea.text === lastSavedContent) {
|
||||
applyingShared = true;
|
||||
lastSavedContent = buffer.baseline;
|
||||
textArea.text = buffer.content;
|
||||
applyingShared = false;
|
||||
syncContentToPlugin();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -152,9 +152,6 @@ Item {
|
||||
}
|
||||
]
|
||||
|
||||
readonly property var entryActionKeys: ["pin", "edit", "delete"]
|
||||
readonly property var entryActionLabels: [I18n.tr("Pin"), I18n.tr("Edit"), I18n.tr("Delete")]
|
||||
|
||||
function getMaxHistoryText(value) {
|
||||
if (value <= 0)
|
||||
return "∞";
|
||||
@@ -190,29 +187,6 @@ Item {
|
||||
return value.toString();
|
||||
}
|
||||
|
||||
function visibleEntryActionKeys() {
|
||||
return SettingsData.clipboardVisibleEntryActions || ["pin", "edit", "delete"];
|
||||
}
|
||||
|
||||
function visibleEntryActionLabels() {
|
||||
const visibleKeys = visibleEntryActionKeys();
|
||||
return entryActionKeys.map((key, index) => visibleKeys.includes(key) ? entryActionLabels[index] : null).filter(label => label !== null);
|
||||
}
|
||||
|
||||
function setVisibleEntryAction(index, selected) {
|
||||
const actionKey = entryActionKeys[index];
|
||||
if (!actionKey)
|
||||
return;
|
||||
|
||||
let actions = visibleEntryActionKeys().slice();
|
||||
if (selected && !actions.includes(actionKey)) {
|
||||
actions.push(actionKey);
|
||||
} else if (!selected && actions.includes(actionKey)) {
|
||||
actions = actions.filter(action => action !== actionKey);
|
||||
}
|
||||
SettingsData.set("clipboardVisibleEntryActions", actions);
|
||||
}
|
||||
|
||||
function loadConfig() {
|
||||
configLoaded = false;
|
||||
configError = false;
|
||||
@@ -463,24 +437,6 @@ Item {
|
||||
checked: SettingsData.clipboardEnterToPaste
|
||||
onToggled: checked => SettingsData.set("clipboardEnterToPaste", checked)
|
||||
}
|
||||
|
||||
SettingsButtonGroupRow {
|
||||
tab: "clipboard"
|
||||
tags: ["clipboard", "actions", "buttons", "hide", "density", "pin", "edit", "delete"]
|
||||
settingKey: "clipboardVisibleEntryActions"
|
||||
text: I18n.tr("Visible Entry Actions")
|
||||
description: I18n.tr("Choose which action buttons appear on clipboard entries")
|
||||
selectionMode: "multi"
|
||||
model: root.entryActionLabels
|
||||
currentSelection: root.visibleEntryActionLabels()
|
||||
checkEnabled: false
|
||||
buttonHeight: 28
|
||||
minButtonWidth: 56
|
||||
buttonPadding: Theme.spacingS
|
||||
textSize: Theme.fontSizeSmall
|
||||
spacing: 1
|
||||
onSelectionChanged: (index, selected) => root.setVisibleEntryAction(index, selected)
|
||||
}
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
|
||||
@@ -23,9 +23,9 @@ Item {
|
||||
SettingsCard {
|
||||
width: parent.width
|
||||
tags: ["niri", "layout", "gaps", "radius", "window", "border"]
|
||||
title: I18n.tr("Niri Layout Overrides")
|
||||
title: I18n.tr("Niri Layout Overrides").replace("Niri", "niri")
|
||||
settingKey: "niriLayout"
|
||||
iconName: "layers"
|
||||
iconName: "crop_square"
|
||||
visible: CompositorService.isNiri
|
||||
|
||||
SettingsToggleRow {
|
||||
|
||||
@@ -796,81 +796,18 @@ Item {
|
||||
}
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
tab: "appearance"
|
||||
iconName: "opacity"
|
||||
title: I18n.tr("Opacity")
|
||||
settingKey: "barTransparency"
|
||||
visible: dankBarTab.appearanceOnly && selectedBarConfig?.enabled
|
||||
|
||||
SettingsSliderRow {
|
||||
id: barTransparencySlider
|
||||
visible: !SettingsData.frameEnabled
|
||||
text: I18n.tr("Bar Opacity")
|
||||
description: I18n.tr("Controls opacity of the bar background")
|
||||
value: (selectedBarConfig?.transparency ?? 1.0) * 100
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: "%"
|
||||
defaultValue: 100
|
||||
onSliderDragFinished: finalValue => {
|
||||
SettingsData.updateBarConfig(selectedBarId, {
|
||||
transparency: finalValue / 100
|
||||
});
|
||||
}
|
||||
|
||||
Binding {
|
||||
target: barTransparencySlider
|
||||
property: "value"
|
||||
value: (selectedBarConfig?.transparency ?? 1.0) * 100
|
||||
restoreMode: Binding.RestoreBinding
|
||||
}
|
||||
}
|
||||
|
||||
SettingsSliderRow {
|
||||
id: widgetTransparencySlider
|
||||
text: I18n.tr("Widget Opacity")
|
||||
description: I18n.tr("Controls opacity of widget backgrounds")
|
||||
value: (selectedBarConfig?.widgetTransparency ?? 1.0) * 100
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: "%"
|
||||
defaultValue: 100
|
||||
onSliderDragFinished: finalValue => {
|
||||
SettingsData.updateBarConfig(selectedBarId, {
|
||||
widgetTransparency: finalValue / 100
|
||||
});
|
||||
}
|
||||
|
||||
Binding {
|
||||
target: widgetTransparencySlider
|
||||
property: "value"
|
||||
value: (selectedBarConfig?.widgetTransparency ?? 1.0) * 100
|
||||
restoreMode: Binding.RestoreBinding
|
||||
}
|
||||
}
|
||||
|
||||
SettingsControlledByFrame {
|
||||
visible: SettingsData.frameEnabled
|
||||
parentModal: dankBarTab.parentModal
|
||||
settingLabel: I18n.tr("Bar Opacity")
|
||||
reason: I18n.tr("Managed by Frame")
|
||||
}
|
||||
}
|
||||
|
||||
SettingsControlledByFrame {
|
||||
visible: dankBarTab.appearanceOnly && SettingsData.frameEnabled
|
||||
visible: !dankBarTab.appearanceOnly && SettingsData.frameEnabled
|
||||
parentModal: dankBarTab.parentModal
|
||||
settingLabel: I18n.tr("Bar spacing and size")
|
||||
reason: I18n.tr("Managed by Frame")
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
tab: "appearance"
|
||||
iconName: "space_bar"
|
||||
title: I18n.tr("Spacing")
|
||||
settingKey: "barSpacing"
|
||||
visible: dankBarTab.appearanceOnly && (selectedBarConfig?.enabled ?? false) && !SettingsData.frameEnabled
|
||||
visible: !dankBarTab.appearanceOnly && (selectedBarConfig?.enabled ?? false) && !SettingsData.frameEnabled
|
||||
|
||||
SettingsSliderRow {
|
||||
id: edgeSpacingSlider
|
||||
@@ -1019,6 +956,68 @@ Item {
|
||||
}
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
tab: "appearance"
|
||||
iconName: "opacity"
|
||||
title: I18n.tr("Transparency")
|
||||
settingKey: "barTransparency"
|
||||
visible: dankBarTab.appearanceOnly && selectedBarConfig?.enabled
|
||||
|
||||
SettingsSliderRow {
|
||||
id: barTransparencySlider
|
||||
visible: !SettingsData.frameEnabled
|
||||
text: I18n.tr("Bar Transparency")
|
||||
description: I18n.tr("Opacity of the bar background")
|
||||
value: (selectedBarConfig?.transparency ?? 1.0) * 100
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: "%"
|
||||
defaultValue: 100
|
||||
onSliderDragFinished: finalValue => {
|
||||
SettingsData.updateBarConfig(selectedBarId, {
|
||||
transparency: finalValue / 100
|
||||
});
|
||||
}
|
||||
|
||||
Binding {
|
||||
target: barTransparencySlider
|
||||
property: "value"
|
||||
value: (selectedBarConfig?.transparency ?? 1.0) * 100
|
||||
restoreMode: Binding.RestoreBinding
|
||||
}
|
||||
}
|
||||
|
||||
SettingsSliderRow {
|
||||
id: widgetTransparencySlider
|
||||
text: I18n.tr("Widget Transparency")
|
||||
description: I18n.tr("Opacity of widget backgrounds")
|
||||
value: (selectedBarConfig?.widgetTransparency ?? 1.0) * 100
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: "%"
|
||||
defaultValue: 100
|
||||
onSliderDragFinished: finalValue => {
|
||||
SettingsData.updateBarConfig(selectedBarId, {
|
||||
widgetTransparency: finalValue / 100
|
||||
});
|
||||
}
|
||||
|
||||
Binding {
|
||||
target: widgetTransparencySlider
|
||||
property: "value"
|
||||
value: (selectedBarConfig?.widgetTransparency ?? 1.0) * 100
|
||||
restoreMode: Binding.RestoreBinding
|
||||
}
|
||||
}
|
||||
|
||||
SettingsControlledByFrame {
|
||||
visible: SettingsData.frameEnabled
|
||||
parentModal: dankBarTab.parentModal
|
||||
settingLabel: I18n.tr("Bar Transparency")
|
||||
reason: I18n.tr("Managed by Frame")
|
||||
}
|
||||
}
|
||||
|
||||
SettingsSliderCard {
|
||||
id: fontScaleSliderCard
|
||||
tab: "appearance"
|
||||
@@ -1359,7 +1358,7 @@ Item {
|
||||
SettingsSliderRow {
|
||||
id: borderOpacitySlider
|
||||
text: I18n.tr("Opacity")
|
||||
description: I18n.tr("Controls opacity of the border")
|
||||
description: I18n.tr("Transparency of the border")
|
||||
value: (selectedBarConfig?.borderOpacity ?? 1.0) * 100
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
@@ -1454,7 +1453,7 @@ Item {
|
||||
SettingsSliderRow {
|
||||
id: widgetOutlineOpacitySlider
|
||||
text: I18n.tr("Opacity")
|
||||
description: I18n.tr("Controls opacity of the widget outline")
|
||||
description: I18n.tr("Transparency of the widget outline")
|
||||
value: (selectedBarConfig?.widgetOutlineOpacity ?? 1.0) * 100
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
@@ -1563,7 +1562,7 @@ Item {
|
||||
SettingsSliderRow {
|
||||
visible: shadowCard.shadowActive
|
||||
text: I18n.tr("Opacity")
|
||||
description: I18n.tr("Controls opacity of the shadow layer")
|
||||
description: I18n.tr("Transparency of the shadow layer")
|
||||
minimum: 10
|
||||
maximum: 100
|
||||
unit: "%"
|
||||
|
||||
@@ -643,19 +643,19 @@ Item {
|
||||
SettingsControlledByFrame {
|
||||
visible: root.connectedFrameModeActive
|
||||
parentModal: root.parentModal
|
||||
settingLabel: I18n.tr("Dock margin, opacity, and border")
|
||||
settingLabel: I18n.tr("Dock margin, transparency, and border")
|
||||
reason: I18n.tr("Managed by Frame in Connected Mode")
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
width: parent.width
|
||||
iconName: "opacity"
|
||||
title: I18n.tr("Opacity")
|
||||
title: I18n.tr("Transparency")
|
||||
settingKey: "dockTransparency"
|
||||
visible: !root.connectedFrameModeActive
|
||||
|
||||
SettingsSliderRow {
|
||||
text: I18n.tr("Dock Opacity")
|
||||
text: I18n.tr("Dock Transparency")
|
||||
value: Math.round(SettingsData.dockTransparency * 100)
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
|
||||
@@ -113,13 +113,6 @@ Item {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
SettingsToggleRow {
|
||||
text: I18n.tr("Device list scroll volume")
|
||||
description: I18n.tr("Allow adjusting device volume by scrolling on the right half of items in the device list")
|
||||
checked: SettingsData.audioDeviceScrollVolumeEnabled
|
||||
onToggled: checked => SettingsData.set("audioDeviceScrollVolumeEnabled", checked)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,462 +0,0 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
|
||||
import QtQuick
|
||||
import qs.Common
|
||||
import qs.Modules.Settings.Widgets
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
|
||||
Item {
|
||||
id: networkEthernetTab
|
||||
|
||||
LayoutMirroring.enabled: I18n.isRtl
|
||||
LayoutMirroring.childrenInherit: true
|
||||
|
||||
Component.onCompleted: {
|
||||
NetworkService.addRef();
|
||||
}
|
||||
|
||||
Component.onDestruction: {
|
||||
NetworkService.removeRef();
|
||||
}
|
||||
|
||||
DankFlickable {
|
||||
anchors.fill: parent
|
||||
clip: true
|
||||
contentHeight: mainColumn.height + Theme.spacingXL
|
||||
contentWidth: width
|
||||
|
||||
Column {
|
||||
id: mainColumn
|
||||
|
||||
topPadding: 4
|
||||
width: Math.min(600, parent.width - Theme.spacingL * 2)
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
spacing: Theme.spacingL
|
||||
|
||||
SettingsCard {
|
||||
id: root
|
||||
|
||||
property string expandedEthDevice: ""
|
||||
|
||||
title: I18n.tr("Ethernet")
|
||||
iconName: "settings_ethernet"
|
||||
settingKey: "networkEthernet"
|
||||
tags: ["ethernet", "wired", "network", "adapters", "connection"]
|
||||
|
||||
width: parent.width
|
||||
|
||||
Column {
|
||||
id: ethernetSection
|
||||
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
|
||||
StyledText {
|
||||
text: {
|
||||
const devices = NetworkService.ethernetDevices;
|
||||
const connected = devices.filter(d => d.connected).length;
|
||||
if (devices.length === 0)
|
||||
return I18n.tr("No adapters");
|
||||
if (connected === 0)
|
||||
return devices.length === 1 ? I18n.tr("%1 adapter, none connected").arg(devices.length) : I18n.tr("%1 adapters, none connected").arg(devices.length);
|
||||
return I18n.tr("%1 connected").arg(connected);
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: NetworkService.ethernetConnected ? Theme.primary : Theme.surfaceVariantText
|
||||
width: parent.width
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.12)
|
||||
}
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: 4
|
||||
visible: NetworkService.ethernetDevices.length > 0
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Adapters")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
width: parent.width
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
}
|
||||
|
||||
Repeater {
|
||||
model: NetworkService.ethernetDevices
|
||||
|
||||
delegate: Rectangle {
|
||||
id: ethDeviceDelegate
|
||||
required property var modelData
|
||||
required property int index
|
||||
|
||||
readonly property bool isConnected: modelData.connected || false
|
||||
readonly property bool isExpanded: root.expandedEthDevice === modelData.name
|
||||
|
||||
width: parent.width
|
||||
height: isExpanded ? 56 + ethExpandedContent.height : 56
|
||||
radius: Theme.cornerRadius
|
||||
color: ethDeviceMouseArea.containsMouse ? Theme.primaryHoverLight : Theme.surfaceLight
|
||||
border.width: isConnected ? 2 : 0
|
||||
border.color: Theme.primary
|
||||
clip: true
|
||||
|
||||
Behavior on height {
|
||||
NumberAnimation {
|
||||
duration: 150
|
||||
easing.type: Easing.OutQuad
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.fill: parent
|
||||
spacing: 0
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: 56
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
anchors.right: ethDeviceActions.left
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "lan"
|
||||
size: 20
|
||||
color: isConnected ? Theme.primary : Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: 2
|
||||
width: parent.width - 20 - Theme.spacingS
|
||||
|
||||
StyledText {
|
||||
text: modelData.name || I18n.tr("Unknown")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: isConnected ? Theme.primary : Theme.surfaceText
|
||||
font.weight: isConnected ? Font.Medium : Font.Normal
|
||||
elide: Text.ElideRight
|
||||
width: parent.width
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
}
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: {
|
||||
switch (modelData.state) {
|
||||
case "activated":
|
||||
return I18n.tr("Connected");
|
||||
case "disconnected":
|
||||
return I18n.tr("Disconnected");
|
||||
case "unavailable":
|
||||
return I18n.tr("Unavailable");
|
||||
default:
|
||||
return modelData.state || I18n.tr("Unknown");
|
||||
}
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: isConnected ? Theme.primary : Theme.surfaceVariantText
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: "•"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
visible: (modelData.ip || "").length > 0
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: modelData.ip || ""
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
visible: (modelData.ip || "").length > 0
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
id: ethDeviceActions
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
Rectangle {
|
||||
width: 28
|
||||
height: 28
|
||||
radius: 14
|
||||
color: ethExpandBtn.containsMouse ? Theme.surfacePressed : "transparent"
|
||||
visible: isConnected
|
||||
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: isExpanded ? "expand_less" : "expand_more"
|
||||
size: 18
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: ethExpandBtn
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (isExpanded) {
|
||||
root.expandedEthDevice = "";
|
||||
} else {
|
||||
root.expandedEthDevice = modelData.name;
|
||||
NetworkService.fetchWiredNetworkInfo(NetworkService.ethernetConnectionUuid);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 28
|
||||
height: 28
|
||||
radius: 14
|
||||
color: ethDisconnectBtn.containsMouse ? Theme.errorHover : "transparent"
|
||||
visible: isConnected
|
||||
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: "link_off"
|
||||
size: 18
|
||||
color: ethDisconnectBtn.containsMouse ? Theme.error : Theme.surfaceVariantText
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: ethDisconnectBtn
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: NetworkService.disconnectEthernetDevice(modelData.name)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: ethDeviceMouseArea
|
||||
anchors.fill: parent
|
||||
anchors.rightMargin: ethDeviceActions.width + Theme.spacingM
|
||||
hoverEnabled: true
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
id: ethExpandedContent
|
||||
width: parent.width
|
||||
visible: isExpanded
|
||||
|
||||
Rectangle {
|
||||
width: parent.width - Theme.spacingM * 2
|
||||
height: 1
|
||||
x: Theme.spacingM
|
||||
color: Theme.outlineLight
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: ethDetailsColumn.implicitHeight + Theme.spacingM * 2
|
||||
|
||||
Column {
|
||||
id: ethDetailsColumn
|
||||
anchors.fill: parent
|
||||
anchors.margins: Theme.spacingM
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Flow {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
Repeater {
|
||||
model: {
|
||||
const fields = [];
|
||||
const dev = modelData;
|
||||
if (!dev)
|
||||
return fields;
|
||||
|
||||
if (dev.ip)
|
||||
fields.push({
|
||||
label: I18n.tr("IP"),
|
||||
value: dev.ip
|
||||
});
|
||||
if (dev.speed && dev.speed > 0)
|
||||
fields.push({
|
||||
label: I18n.tr("Speed"),
|
||||
value: dev.speed + " Mbps"
|
||||
});
|
||||
if (dev.hwAddress)
|
||||
fields.push({
|
||||
label: I18n.tr("MAC"),
|
||||
value: dev.hwAddress
|
||||
});
|
||||
if (dev.driver)
|
||||
fields.push({
|
||||
label: I18n.tr("Driver"),
|
||||
value: dev.driver
|
||||
});
|
||||
fields.push({
|
||||
label: I18n.tr("State"),
|
||||
value: dev.state || I18n.tr("Unknown")
|
||||
});
|
||||
|
||||
return fields;
|
||||
}
|
||||
|
||||
delegate: Rectangle {
|
||||
required property var modelData
|
||||
required property int index
|
||||
|
||||
width: ethFieldContent.width + Theme.spacingM * 2
|
||||
height: 32
|
||||
radius: Theme.cornerRadius - 2
|
||||
color: Theme.surfaceContainerHigh
|
||||
border.width: 1
|
||||
border.color: Theme.outlineLight
|
||||
|
||||
Row {
|
||||
id: ethFieldContent
|
||||
anchors.centerIn: parent
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: modelData.label + ":"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: modelData.value
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Medium
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: NetworkService.networkWiredInfoLoading ? 40 : 0
|
||||
visible: NetworkService.networkWiredInfoLoading
|
||||
|
||||
DankSpinner {
|
||||
anchors.centerIn: parent
|
||||
size: 20
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
visible: NetworkService.wiredConnections.length > 0
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.12)
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Saved Configurations")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
width: parent.width
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
}
|
||||
|
||||
Repeater {
|
||||
model: NetworkService.wiredConnections
|
||||
|
||||
delegate: Rectangle {
|
||||
required property var modelData
|
||||
required property int index
|
||||
|
||||
width: parent.width
|
||||
height: 48
|
||||
radius: Theme.cornerRadius
|
||||
color: wiredMouseArea.containsMouse ? Theme.primaryHoverLight : Theme.surfaceLight
|
||||
border.width: modelData.isActive ? 2 : 0
|
||||
border.color: Theme.primary
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "lan"
|
||||
size: 20
|
||||
color: modelData.isActive ? Theme.primary : Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: 2
|
||||
|
||||
StyledText {
|
||||
text: modelData.id || I18n.tr("Unknown")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: modelData.isActive ? Theme.primary : Theme.surfaceText
|
||||
font.weight: modelData.isActive ? Font.Medium : Font.Normal
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: modelData.isActive ? I18n.tr("Active") : ""
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.primary
|
||||
visible: modelData.isActive
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: wiredMouseArea
|
||||
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (!modelData.isActive) {
|
||||
NetworkService.connectToSpecificWiredConfig(modelData.uuid);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,202 +0,0 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
|
||||
import QtQuick
|
||||
import qs.Common
|
||||
import qs.Modules.Settings.Widgets
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
|
||||
Item {
|
||||
id: networkStatusTab
|
||||
|
||||
LayoutMirroring.enabled: I18n.isRtl
|
||||
LayoutMirroring.childrenInherit: true
|
||||
|
||||
Component.onCompleted: {
|
||||
NetworkService.addRef();
|
||||
}
|
||||
|
||||
Component.onDestruction: {
|
||||
NetworkService.removeRef();
|
||||
}
|
||||
|
||||
DankFlickable {
|
||||
anchors.fill: parent
|
||||
clip: true
|
||||
contentHeight: mainColumn.height + Theme.spacingXL
|
||||
contentWidth: width
|
||||
|
||||
Column {
|
||||
id: mainColumn
|
||||
|
||||
topPadding: 4
|
||||
width: Math.min(600, parent.width - Theme.spacingL * 2)
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
spacing: Theme.spacingL
|
||||
|
||||
SettingsCard {
|
||||
id: root
|
||||
|
||||
title: I18n.tr("Network Status")
|
||||
iconName: "lan"
|
||||
settingKey: "networkStatus"
|
||||
tags: ["status", "network", "connectivity", "internet"]
|
||||
|
||||
width: parent.width
|
||||
|
||||
Column {
|
||||
id: overviewSection
|
||||
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Overview of your network connections")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
width: parent.width
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.12)
|
||||
}
|
||||
|
||||
Grid {
|
||||
columns: 2
|
||||
columnSpacing: Theme.spacingL
|
||||
rowSpacing: Theme.spacingS
|
||||
width: parent.width
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Backend")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
}
|
||||
StyledText {
|
||||
text: NetworkService.backend || I18n.tr("Unknown")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Medium
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Status")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
}
|
||||
Row {
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Rectangle {
|
||||
width: 8
|
||||
height: 8
|
||||
radius: 4
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
color: {
|
||||
switch (NetworkService.networkStatus) {
|
||||
case "ethernet":
|
||||
case "wifi":
|
||||
return Theme.success;
|
||||
case "disconnected":
|
||||
return Theme.error;
|
||||
default:
|
||||
return Theme.warning;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: {
|
||||
switch (NetworkService.networkStatus) {
|
||||
case "ethernet":
|
||||
return I18n.tr("Ethernet");
|
||||
case "wifi":
|
||||
return I18n.tr("WiFi");
|
||||
case "disconnected":
|
||||
return I18n.tr("Disconnected");
|
||||
default:
|
||||
return NetworkService.networkStatus || I18n.tr("Unknown");
|
||||
}
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Medium
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Primary")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
visible: NetworkService.primaryConnection.length > 0
|
||||
}
|
||||
StyledText {
|
||||
text: NetworkService.primaryConnection || "-"
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceText
|
||||
elide: Text.ElideRight
|
||||
visible: NetworkService.primaryConnection.length > 0
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
visible: NetworkService.backend === "networkmanager" && NetworkService.ethernetConnected && NetworkService.wifiConnected
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Preference")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width - preferenceLabel.width - preferenceButtons.width - Theme.spacingM * 2
|
||||
height: 1
|
||||
}
|
||||
|
||||
DankButtonGroup {
|
||||
id: preferenceButtons
|
||||
model: [I18n.tr("Auto"), I18n.tr("Ethernet"), I18n.tr("WiFi")]
|
||||
currentIndex: {
|
||||
switch (NetworkService.userPreference) {
|
||||
case "ethernet":
|
||||
return 1;
|
||||
case "wifi":
|
||||
return 2;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
onSelectionChanged: (index, selected) => {
|
||||
if (!selected)
|
||||
return;
|
||||
switch (index) {
|
||||
case 0:
|
||||
NetworkService.setNetworkPreference("auto");
|
||||
break;
|
||||
case 1:
|
||||
NetworkService.setNetworkPreference("ethernet");
|
||||
break;
|
||||
case 2:
|
||||
NetworkService.setNetworkPreference("wifi");
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
id: preferenceLabel
|
||||
visible: false
|
||||
text: I18n.tr("Preference")
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,516 +0,0 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
|
||||
import QtQuick
|
||||
import Quickshell
|
||||
import qs.Common
|
||||
import qs.Modules.Settings.Widgets
|
||||
import qs.Modals.Common
|
||||
import qs.Modals.FileBrowser
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
|
||||
Item {
|
||||
id: networkVpnTab
|
||||
|
||||
LayoutMirroring.enabled: I18n.isRtl
|
||||
LayoutMirroring.childrenInherit: true
|
||||
|
||||
Component.onCompleted: {
|
||||
NetworkService.addRef();
|
||||
}
|
||||
|
||||
Component.onDestruction: {
|
||||
NetworkService.removeRef();
|
||||
}
|
||||
|
||||
DankFlickable {
|
||||
anchors.fill: parent
|
||||
clip: true
|
||||
contentHeight: mainColumn.height + Theme.spacingXL
|
||||
contentWidth: width
|
||||
|
||||
Column {
|
||||
id: mainColumn
|
||||
|
||||
topPadding: 4
|
||||
width: Math.min(600, parent.width - Theme.spacingL * 2)
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
spacing: Theme.spacingL
|
||||
|
||||
SettingsCard {
|
||||
id: root
|
||||
|
||||
property string expandedVpnUuid: ""
|
||||
|
||||
title: I18n.tr("VPN")
|
||||
iconName: "vpn_key"
|
||||
settingKey: "networkVpn"
|
||||
tags: ["vpn", "network", "profiles", "import", "openvpn", "wireguard"]
|
||||
|
||||
function openVpnFileBrowser() {
|
||||
vpnFileBrowserLoader.active = true;
|
||||
if (vpnFileBrowserLoader.item)
|
||||
vpnFileBrowserLoader.item.open();
|
||||
}
|
||||
|
||||
property var vpnFileBrowserLoader: LazyLoader {
|
||||
active: false
|
||||
|
||||
FileBrowserModal {
|
||||
browserTitle: I18n.tr("Import VPN")
|
||||
browserIcon: "vpn_key"
|
||||
browserType: "vpn"
|
||||
fileExtensions: VPNService.getFileFilter()
|
||||
|
||||
onFileSelected: path => {
|
||||
VPNService.importVpn(path.replace("file://", ""));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
property var deleteVpnConfirm: ConfirmModal {}
|
||||
|
||||
width: parent.width
|
||||
|
||||
Column {
|
||||
id: vpnSection
|
||||
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Unavailable")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
width: parent.width
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
visible: !DMSNetworkService.vpnAvailable
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
visible: DMSNetworkService.vpnAvailable
|
||||
|
||||
StyledText {
|
||||
text: {
|
||||
if (!DMSNetworkService.connected)
|
||||
return I18n.tr("Disconnected");
|
||||
const names = DMSNetworkService.activeNames || [];
|
||||
if (names.length <= 1)
|
||||
return names[0] || I18n.tr("Connected");
|
||||
return names[0] + " +" + (names.length - 1);
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: DMSNetworkService.connected ? Theme.primary : Theme.surfaceVariantText
|
||||
width: parent.width - vpnHeaderControls.width - Theme.spacingM
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Row {
|
||||
id: vpnHeaderControls
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Rectangle {
|
||||
height: 28
|
||||
radius: 14
|
||||
width: importVpnRow.width + Theme.spacingM * 2
|
||||
color: importVpnArea.containsMouse ? Theme.primaryHoverLight : Theme.surfaceLight
|
||||
opacity: VPNService.importing ? 0.5 : 1.0
|
||||
|
||||
Row {
|
||||
id: importVpnRow
|
||||
anchors.centerIn: parent
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
DankIcon {
|
||||
name: VPNService.importing ? "sync" : "add"
|
||||
size: Theme.fontSizeSmall
|
||||
color: Theme.primary
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Import")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.primary
|
||||
font.weight: Font.Medium
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: importVpnArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: VPNService.importing ? Qt.BusyCursor : Qt.PointingHandCursor
|
||||
enabled: !VPNService.importing
|
||||
onClicked: root.openVpnFileBrowser()
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
height: 28
|
||||
radius: 14
|
||||
width: disconnectAllRow.width + Theme.spacingM * 2
|
||||
color: disconnectAllArea.containsMouse ? Theme.errorHover : Theme.surfaceLight
|
||||
visible: DMSNetworkService.connected
|
||||
opacity: DMSNetworkService.isBusy ? 0.5 : 1.0
|
||||
|
||||
Row {
|
||||
id: disconnectAllRow
|
||||
anchors.centerIn: parent
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
DankIcon {
|
||||
name: "link_off"
|
||||
size: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Disconnect")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Medium
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: disconnectAllArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: DMSNetworkService.isBusy ? Qt.BusyCursor : Qt.PointingHandCursor
|
||||
enabled: !DMSNetworkService.isBusy
|
||||
onClicked: DMSNetworkService.disconnectAllActive()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.12)
|
||||
visible: DMSNetworkService.vpnAvailable
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: 100
|
||||
visible: DMSNetworkService.vpnAvailable && DMSNetworkService.profiles.length === 0
|
||||
|
||||
Column {
|
||||
anchors.centerIn: parent
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "vpn_key_off"
|
||||
size: 36
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("No VPN profiles")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Click Import to add a .ovpn or .conf")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: 4
|
||||
visible: DMSNetworkService.vpnAvailable && DMSNetworkService.profiles.length > 0
|
||||
|
||||
Repeater {
|
||||
model: DMSNetworkService.profiles
|
||||
|
||||
delegate: Rectangle {
|
||||
id: vpnProfileRow
|
||||
required property var modelData
|
||||
required property int index
|
||||
|
||||
readonly property bool isActive: DMSNetworkService.isActiveUuid(modelData.uuid)
|
||||
readonly property bool isTransient: !!modelData.transient
|
||||
readonly property bool canExpand: modelData.canExpand !== false
|
||||
readonly property bool canDelete: modelData.canDelete !== false
|
||||
readonly property bool isExpanded: root.expandedVpnUuid === modelData.uuid
|
||||
readonly property var configData: (!isTransient && isExpanded) ? VPNService.editConfig : null
|
||||
|
||||
width: parent.width
|
||||
height: isExpanded ? 56 + vpnExpandedContent.height : 56
|
||||
radius: Theme.cornerRadius
|
||||
color: vpnRowArea.containsMouse ? Theme.primaryHoverLight : (isActive ? Theme.primaryPressed : Theme.surfaceLight)
|
||||
border.width: isActive ? 2 : 0
|
||||
border.color: Theme.primary
|
||||
opacity: DMSNetworkService.isBusy ? 0.6 : 1.0
|
||||
clip: true
|
||||
|
||||
Behavior on height {
|
||||
NumberAnimation {
|
||||
duration: 150
|
||||
easing.type: Easing.OutQuad
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: vpnRowArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: DMSNetworkService.isBusy ? Qt.BusyCursor : Qt.PointingHandCursor
|
||||
enabled: !DMSNetworkService.isBusy
|
||||
onClicked: DMSNetworkService.toggle(modelData.uuid)
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.fill: parent
|
||||
anchors.margins: Theme.spacingS
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
height: 56 - Theme.spacingS * 2
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: isActive ? "vpn_lock" : "vpn_key_off"
|
||||
size: 20
|
||||
color: isActive ? Theme.primary : Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Column {
|
||||
spacing: 2
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
width: parent.width - 20 - ((canExpand ? 28 : 0) + (canDelete ? 28 : 0)) - Theme.spacingS * 4
|
||||
|
||||
StyledText {
|
||||
text: modelData.name
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: isActive ? Theme.primary : Theme.surfaceText
|
||||
elide: Text.ElideRight
|
||||
width: parent.width
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: VPNService.getVpnTypeFromProfile(modelData)
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.left: parent.left
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
width: Theme.spacingXS
|
||||
height: 1
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 28
|
||||
height: 28
|
||||
radius: 14
|
||||
color: vpnExpandBtn.containsMouse ? Theme.surfacePressed : "transparent"
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
visible: canExpand
|
||||
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: isExpanded ? "expand_less" : "expand_more"
|
||||
size: 18
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: vpnExpandBtn
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (isExpanded) {
|
||||
root.expandedVpnUuid = "";
|
||||
} else {
|
||||
root.expandedVpnUuid = modelData.uuid;
|
||||
VPNService.getConfig(modelData.uuid);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: 28
|
||||
height: 28
|
||||
radius: 14
|
||||
color: vpnDeleteBtn.containsMouse ? Theme.errorHover : "transparent"
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
visible: canDelete
|
||||
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: "delete"
|
||||
size: 18
|
||||
color: vpnDeleteBtn.containsMouse ? Theme.error : Theme.surfaceVariantText
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: vpnDeleteBtn
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
deleteVpnConfirm.showWithOptions({
|
||||
title: I18n.tr("Delete VPN"),
|
||||
message: I18n.tr("Delete \"%1\"?").arg(modelData.name),
|
||||
confirmText: I18n.tr("Delete"),
|
||||
confirmColor: Theme.error,
|
||||
onConfirm: () => VPNService.deleteVpn(modelData.uuid)
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
id: vpnExpandedContent
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
visible: !isTransient && isExpanded
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Theme.outlineLight
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: VPNService.configLoading ? 40 : 0
|
||||
visible: VPNService.configLoading
|
||||
|
||||
DankSpinner {
|
||||
anchors.centerIn: parent
|
||||
size: 20
|
||||
}
|
||||
}
|
||||
|
||||
Flow {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
visible: !VPNService.configLoading && configData
|
||||
|
||||
Repeater {
|
||||
model: {
|
||||
if (!configData)
|
||||
return [];
|
||||
const fields = [];
|
||||
const data = configData.data || {};
|
||||
|
||||
if (data.remote)
|
||||
fields.push({
|
||||
label: I18n.tr("Server"),
|
||||
value: data.remote
|
||||
});
|
||||
if (configData.username || data.username)
|
||||
fields.push({
|
||||
label: I18n.tr("Username"),
|
||||
value: configData.username || data.username
|
||||
});
|
||||
if (data.cipher)
|
||||
fields.push({
|
||||
label: I18n.tr("Cipher"),
|
||||
value: data.cipher
|
||||
});
|
||||
if (data.auth)
|
||||
fields.push({
|
||||
label: I18n.tr("Auth"),
|
||||
value: data.auth
|
||||
});
|
||||
if (data["proto-tcp"] === "yes" || data["proto-tcp"] === "no")
|
||||
fields.push({
|
||||
label: I18n.tr("Protocol"),
|
||||
value: data["proto-tcp"] === "yes" ? "TCP" : "UDP"
|
||||
});
|
||||
if (data["tunnel-mtu"])
|
||||
fields.push({
|
||||
label: I18n.tr("MTU"),
|
||||
value: data["tunnel-mtu"]
|
||||
});
|
||||
if (data["connection-type"])
|
||||
fields.push({
|
||||
label: I18n.tr("Auth Type"),
|
||||
value: data["connection-type"]
|
||||
});
|
||||
return fields;
|
||||
}
|
||||
|
||||
delegate: Rectangle {
|
||||
required property var modelData
|
||||
required property int index
|
||||
|
||||
width: vpnFieldContent.width + Theme.spacingM * 2
|
||||
height: 32
|
||||
radius: Theme.cornerRadius - 2
|
||||
color: Theme.surfaceContainerHigh
|
||||
border.width: 1
|
||||
border.color: Theme.outlineLight
|
||||
|
||||
Row {
|
||||
id: vpnFieldContent
|
||||
anchors.centerIn: parent
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: modelData.label + ":"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: modelData.value
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Medium
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
width: parent.width
|
||||
text: I18n.tr("Autoconnect")
|
||||
checked: configData ? (configData.autoconnect || false) : false
|
||||
visible: !VPNService.configLoading && configData !== null
|
||||
onToggled: checked => {
|
||||
VPNService.updateConfig(modelData.uuid, {
|
||||
autoconnect: checked
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
width: 1
|
||||
height: Theme.spacingXS
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,761 +0,0 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
|
||||
import QtQuick
|
||||
import QtQuick.Layouts
|
||||
import qs.Common
|
||||
import qs.Modules.Settings.Widgets
|
||||
import qs.Modals.Common
|
||||
import qs.Services
|
||||
import qs.Widgets
|
||||
|
||||
Item {
|
||||
id: networkWifiTab
|
||||
|
||||
LayoutMirroring.enabled: I18n.isRtl
|
||||
LayoutMirroring.childrenInherit: true
|
||||
|
||||
Component.onCompleted: {
|
||||
NetworkService.addRef();
|
||||
}
|
||||
|
||||
Component.onDestruction: {
|
||||
NetworkService.removeRef();
|
||||
}
|
||||
|
||||
DankFlickable {
|
||||
anchors.fill: parent
|
||||
clip: true
|
||||
contentHeight: mainColumn.height + Theme.spacingXL
|
||||
contentWidth: width
|
||||
|
||||
Column {
|
||||
id: mainColumn
|
||||
|
||||
topPadding: 4
|
||||
width: Math.min(600, parent.width - Theme.spacingL * 2)
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
spacing: Theme.spacingL
|
||||
|
||||
SettingsCard {
|
||||
id: root
|
||||
|
||||
property string expandedWifiSsid: ""
|
||||
property int maxPinnedWifiNetworks: 3
|
||||
|
||||
function normalizePinList(value) {
|
||||
if (Array.isArray(value))
|
||||
return value.filter(v => v);
|
||||
if (typeof value === "string" && value.length > 0)
|
||||
return [value];
|
||||
return [];
|
||||
}
|
||||
|
||||
function getPinnedWifiNetworks() {
|
||||
const pins = SettingsData.wifiNetworkPins || {};
|
||||
return normalizePinList(pins["preferredWifi"]);
|
||||
}
|
||||
|
||||
function toggleWifiPin(ssid) {
|
||||
const pins = JSON.parse(JSON.stringify(SettingsData.wifiNetworkPins || {}));
|
||||
let pinnedList = normalizePinList(pins["preferredWifi"]);
|
||||
const pinIndex = pinnedList.indexOf(ssid);
|
||||
|
||||
if (pinIndex !== -1) {
|
||||
pinnedList.splice(pinIndex, 1);
|
||||
} else {
|
||||
pinnedList.unshift(ssid);
|
||||
if (pinnedList.length > maxPinnedWifiNetworks)
|
||||
pinnedList = pinnedList.slice(0, maxPinnedWifiNetworks);
|
||||
}
|
||||
|
||||
if (pinnedList.length > 0)
|
||||
pins["preferredWifi"] = pinnedList;
|
||||
else
|
||||
delete pins["preferredWifi"];
|
||||
|
||||
SettingsData.set("wifiNetworkPins", pins);
|
||||
}
|
||||
|
||||
property var forgetNetworkConfirm: ConfirmModal {}
|
||||
|
||||
width: parent.width
|
||||
title: I18n.tr("WiFi")
|
||||
iconName: "wifi"
|
||||
settingKey: "networkWifi"
|
||||
tags: ["wifi", "wi-fi", "wireless", "network", "ssid", "adapter", "radio"]
|
||||
|
||||
Column {
|
||||
id: wifiSection
|
||||
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
|
||||
StyledText {
|
||||
text: {
|
||||
if (NetworkService.wifiToggling)
|
||||
return I18n.tr("Toggling...");
|
||||
if (!NetworkService.wifiEnabled)
|
||||
return I18n.tr("Disabled");
|
||||
if (NetworkService.wifiConnected)
|
||||
return NetworkService.currentWifiSSID;
|
||||
return I18n.tr("Not connected");
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: NetworkService.wifiConnected ? Theme.primary : Theme.surfaceVariantText
|
||||
width: parent.width - wifiControls.width - Theme.spacingM
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Row {
|
||||
id: wifiControls
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankActionButton {
|
||||
iconName: "wifi_find"
|
||||
buttonSize: 32
|
||||
visible: NetworkService.backend === "networkmanager" && NetworkService.wifiEnabled && !NetworkService.wifiToggling
|
||||
onClicked: PopoutService.showHiddenNetworkModal()
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
iconName: "refresh"
|
||||
buttonSize: 32
|
||||
visible: NetworkService.wifiEnabled && !NetworkService.wifiToggling && !NetworkService.isScanning
|
||||
onClicked: NetworkService.scanWifi()
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
checked: NetworkService.wifiEnabled
|
||||
enabled: !NetworkService.wifiToggling
|
||||
onToggled: NetworkService.toggleWifiRadio()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
visible: NetworkService.wifiEnabled && (NetworkService.wifiDevices?.length ?? 0) > 1
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("WiFi Device")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width - wifiDeviceLabel.width - wifiDeviceDropdown.width - Theme.spacingM * 2
|
||||
height: 1
|
||||
}
|
||||
|
||||
DankDropdown {
|
||||
id: wifiDeviceDropdown
|
||||
dropdownWidth: 150
|
||||
popupWidth: 180
|
||||
currentValue: NetworkService.wifiDeviceOverride || I18n.tr("Auto")
|
||||
options: {
|
||||
const devices = NetworkService.wifiDevices;
|
||||
if (!devices || devices.length === 0)
|
||||
return [I18n.tr("Auto")];
|
||||
return [I18n.tr("Auto")].concat(devices.map(d => d.name));
|
||||
}
|
||||
onValueChanged: value => {
|
||||
const deviceName = value === I18n.tr("Auto") ? "" : value;
|
||||
NetworkService.setWifiDeviceOverride(deviceName);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
id: wifiDeviceLabel
|
||||
visible: false
|
||||
text: I18n.tr("WiFi Device")
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
color: Qt.rgba(Theme.outline.r, Theme.outline.g, Theme.outline.b, 0.12)
|
||||
visible: NetworkService.wifiEnabled
|
||||
}
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
visible: NetworkService.wifiEnabled && !NetworkService.wifiToggling
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingS
|
||||
visible: NetworkService.wifiInterface.length > 0
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
height: 24
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Interface:")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
width: 100
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
StyledText {
|
||||
text: NetworkService.wifiInterface || "-"
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
height: 24
|
||||
visible: NetworkService.wifiIP.length > 0
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("IP Address:")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
width: 100
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
StyledText {
|
||||
text: NetworkService.wifiIP || "-"
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
height: 24
|
||||
visible: NetworkService.wifiConnected
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Signal:")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceVariantText
|
||||
width: 100
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Row {
|
||||
spacing: Theme.spacingXS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
|
||||
DankIcon {
|
||||
name: {
|
||||
const s = NetworkService.wifiSignalStrength;
|
||||
if (s >= 50)
|
||||
return "wifi";
|
||||
if (s >= 25)
|
||||
return "wifi_2_bar";
|
||||
return "wifi_1_bar";
|
||||
}
|
||||
size: 18
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: NetworkService.wifiSignalStrength + "%"
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: Theme.spacingS
|
||||
}
|
||||
|
||||
Row {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingM
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Available Networks")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
font.weight: Font.Medium
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Item {
|
||||
width: 1
|
||||
height: 1
|
||||
Layout.fillWidth: true
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: NetworkService.wifiNetworks?.length ?? 0
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: 80
|
||||
visible: NetworkService.isScanning && (NetworkService.wifiNetworks?.length ?? 0) === 0
|
||||
|
||||
Column {
|
||||
anchors.centerIn: parent
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
id: scanningIcon
|
||||
name: "wifi_find"
|
||||
size: 32
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
|
||||
SequentialAnimation {
|
||||
running: NetworkService.isScanning
|
||||
loops: Animation.Infinite
|
||||
OpacityAnimator {
|
||||
target: scanningIcon
|
||||
to: 0.3
|
||||
duration: 400
|
||||
easing.type: Easing.InOutQuad
|
||||
}
|
||||
OpacityAnimator {
|
||||
target: scanningIcon
|
||||
to: 1.0
|
||||
duration: 400
|
||||
easing.type: Easing.InOutQuad
|
||||
}
|
||||
onRunningChanged: if (!running)
|
||||
scanningIcon.opacity = 1.0
|
||||
}
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Scanning...")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
spacing: 4
|
||||
visible: (NetworkService.wifiNetworks?.length ?? 0) > 0
|
||||
|
||||
Repeater {
|
||||
model: {
|
||||
const ssid = NetworkService.currentWifiSSID;
|
||||
const networks = NetworkService.wifiNetworks || [];
|
||||
const pinnedList = root.getPinnedWifiNetworks();
|
||||
|
||||
let sorted = [...networks];
|
||||
sorted.sort((a, b) => {
|
||||
const aPinnedIndex = pinnedList.indexOf(a.ssid);
|
||||
const bPinnedIndex = pinnedList.indexOf(b.ssid);
|
||||
if (aPinnedIndex !== -1 || bPinnedIndex !== -1) {
|
||||
if (aPinnedIndex === -1)
|
||||
return 1;
|
||||
if (bPinnedIndex === -1)
|
||||
return -1;
|
||||
return aPinnedIndex - bPinnedIndex;
|
||||
}
|
||||
if (a.ssid === ssid)
|
||||
return -1;
|
||||
if (b.ssid === ssid)
|
||||
return 1;
|
||||
return b.signal - a.signal;
|
||||
});
|
||||
return sorted;
|
||||
}
|
||||
|
||||
delegate: Rectangle {
|
||||
id: wifiNetworkDelegate
|
||||
required property var modelData
|
||||
required property int index
|
||||
|
||||
readonly property bool isConnected: modelData.ssid === NetworkService.currentWifiSSID
|
||||
readonly property bool isPinned: root.getPinnedWifiNetworks().includes(modelData.ssid)
|
||||
readonly property bool isExpanded: root.expandedWifiSsid === modelData.ssid
|
||||
|
||||
width: parent.width
|
||||
height: isExpanded ? 56 + wifiExpandedContent.height : 56
|
||||
radius: Theme.cornerRadius
|
||||
color: wifiNetworkMouseArea.containsMouse ? Theme.primaryHoverLight : Theme.surfaceLight
|
||||
border.width: isConnected ? 2 : 0
|
||||
border.color: Theme.primary
|
||||
clip: true
|
||||
|
||||
Behavior on height {
|
||||
NumberAnimation {
|
||||
duration: 150
|
||||
easing.type: Easing.OutQuad
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.fill: parent
|
||||
spacing: 0
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: 56
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
anchors.right: wifiNetworkActions.left
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: {
|
||||
const s = modelData.signal || 0;
|
||||
if (s >= 50)
|
||||
return "wifi";
|
||||
if (s >= 25)
|
||||
return "wifi_2_bar";
|
||||
return "wifi_1_bar";
|
||||
}
|
||||
size: 20
|
||||
color: isConnected ? Theme.primary : Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
Column {
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: 2
|
||||
width: parent.width - 20 - Theme.spacingS
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: modelData.ssid || I18n.tr("Unknown")
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
color: isConnected ? Theme.primary : Theme.surfaceText
|
||||
font.weight: isConnected ? Font.Medium : Font.Normal
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
|
||||
DankIcon {
|
||||
name: "push_pin"
|
||||
size: 14
|
||||
color: Theme.primary
|
||||
visible: isPinned
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
DankIcon {
|
||||
name: "visibility_off"
|
||||
size: 14
|
||||
color: Theme.surfaceVariantText
|
||||
visible: modelData.hidden || false
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: isConnected ? I18n.tr("Connected") : (modelData.secured ? I18n.tr("Secured") : I18n.tr("Open"))
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: isConnected ? Theme.primary : Theme.surfaceVariantText
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: "•"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
visible: modelData.saved
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Saved")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.primary
|
||||
visible: modelData.saved
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: "•"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
visible: modelData.hidden || false
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Hidden")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
visible: modelData.hidden || false
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: "•"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: modelData.signal + "%"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
id: wifiNetworkActions
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
Rectangle {
|
||||
width: 28
|
||||
height: 28
|
||||
radius: 14
|
||||
color: wifiExpandBtn.containsMouse ? Theme.surfacePressed : "transparent"
|
||||
visible: isConnected || modelData.saved
|
||||
|
||||
DankIcon {
|
||||
anchors.centerIn: parent
|
||||
name: isExpanded ? "expand_less" : "expand_more"
|
||||
size: 18
|
||||
color: Theme.surfaceText
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: wifiExpandBtn
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (isExpanded) {
|
||||
root.expandedWifiSsid = "";
|
||||
} else {
|
||||
root.expandedWifiSsid = modelData.ssid;
|
||||
NetworkService.fetchNetworkInfo(modelData.ssid);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
iconName: "qr_code"
|
||||
buttonSize: 28
|
||||
visible: modelData.secured && modelData.saved
|
||||
onClicked: {
|
||||
PopoutService.showWifiQRCodeModal(modelData.ssid);
|
||||
}
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
iconName: isPinned ? "push_pin" : "push_pin"
|
||||
buttonSize: 28
|
||||
iconColor: isPinned ? Theme.primary : Theme.surfaceVariantText
|
||||
onClicked: {
|
||||
root.toggleWifiPin(modelData.ssid);
|
||||
}
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
iconName: "delete"
|
||||
buttonSize: 28
|
||||
iconColor: Theme.error
|
||||
visible: modelData.saved || isConnected
|
||||
onClicked: {
|
||||
forgetNetworkConfirm.showWithOptions({
|
||||
title: I18n.tr("Forget Network"),
|
||||
message: I18n.tr("Forget \"%1\"?").arg(modelData.ssid),
|
||||
confirmText: I18n.tr("Forget"),
|
||||
confirmColor: Theme.error,
|
||||
onConfirm: () => NetworkService.forgetWifiNetwork(modelData.ssid)
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: wifiNetworkMouseArea
|
||||
|
||||
anchors.fill: parent
|
||||
anchors.rightMargin: wifiNetworkActions.width + Theme.spacingM
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (isConnected) {
|
||||
NetworkService.disconnectWifi();
|
||||
return;
|
||||
}
|
||||
if (modelData.secured && !modelData.saved && (DMSService.apiVersion < 7 || modelData.enterprise)) {
|
||||
PopoutService.showWifiPasswordModal(modelData.ssid);
|
||||
return;
|
||||
}
|
||||
NetworkService.connectToWifi(modelData.ssid);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
id: wifiExpandedContent
|
||||
width: parent.width
|
||||
visible: isExpanded
|
||||
|
||||
Rectangle {
|
||||
width: parent.width - Theme.spacingM * 2
|
||||
height: 1
|
||||
x: Theme.spacingM
|
||||
color: Theme.outlineLight
|
||||
}
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: wifiDetailsColumn.implicitHeight + Theme.spacingM * 2
|
||||
|
||||
Column {
|
||||
id: wifiDetailsColumn
|
||||
anchors.fill: parent
|
||||
anchors.margins: Theme.spacingM
|
||||
spacing: Theme.spacingS
|
||||
|
||||
Item {
|
||||
width: parent.width
|
||||
height: NetworkService.networkInfoLoading ? 40 : 0
|
||||
visible: NetworkService.networkInfoLoading
|
||||
|
||||
DankSpinner {
|
||||
anchors.centerIn: parent
|
||||
size: 20
|
||||
}
|
||||
}
|
||||
|
||||
Flow {
|
||||
width: parent.width
|
||||
spacing: Theme.spacingXS
|
||||
visible: !NetworkService.networkInfoLoading
|
||||
|
||||
Repeater {
|
||||
model: {
|
||||
const fields = [];
|
||||
const net = modelData;
|
||||
if (!net)
|
||||
return fields;
|
||||
|
||||
fields.push({
|
||||
label: I18n.tr("Signal"),
|
||||
value: net.signal + "%"
|
||||
});
|
||||
if (net.frequency)
|
||||
fields.push({
|
||||
label: I18n.tr("Frequency"),
|
||||
value: (net.frequency / 1000).toFixed(1) + " GHz"
|
||||
});
|
||||
if (net.channel)
|
||||
fields.push({
|
||||
label: I18n.tr("Channel"),
|
||||
value: String(net.channel)
|
||||
});
|
||||
if (net.rate)
|
||||
fields.push({
|
||||
label: I18n.tr("Rate"),
|
||||
value: net.rate + " Mbps"
|
||||
});
|
||||
if (net.mode)
|
||||
fields.push({
|
||||
label: I18n.tr("Mode"),
|
||||
value: net.mode
|
||||
});
|
||||
if (net.bssid)
|
||||
fields.push({
|
||||
label: I18n.tr("BSSID"),
|
||||
value: net.bssid
|
||||
});
|
||||
fields.push({
|
||||
label: I18n.tr("Security"),
|
||||
value: net.secured ? (net.enterprise ? I18n.tr("Enterprise") : I18n.tr("WPA/WPA2")) : I18n.tr("Open")
|
||||
});
|
||||
|
||||
return fields;
|
||||
}
|
||||
|
||||
delegate: Rectangle {
|
||||
required property var modelData
|
||||
required property int index
|
||||
|
||||
width: wifiFieldContent.width + Theme.spacingM * 2
|
||||
height: 32
|
||||
radius: Theme.cornerRadius - 2
|
||||
color: Theme.surfaceContainerHigh
|
||||
border.width: 1
|
||||
border.color: Theme.outlineLight
|
||||
|
||||
Row {
|
||||
id: wifiFieldContent
|
||||
anchors.centerIn: parent
|
||||
spacing: Theme.spacingXS
|
||||
|
||||
StyledText {
|
||||
text: modelData.label + ":"
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceVariantText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: modelData.value
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Medium
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
spacing: Theme.spacingS
|
||||
visible: (modelData.saved || isConnected) && DMSService.apiVersion > 13
|
||||
|
||||
DankToggle {
|
||||
id: autoconnectToggle
|
||||
text: I18n.tr("Autoconnect")
|
||||
checked: modelData.autoconnect || false
|
||||
onToggled: checked => {
|
||||
NetworkService.setWifiAutoconnect(modelData.ssid, checked);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1639,7 +1639,7 @@ Item {
|
||||
SettingsControlledByFrame {
|
||||
visible: themeColorsTab.connectedFrameModeActive
|
||||
parentModal: themeColorsTab.parentModal
|
||||
settingLabel: I18n.tr("Surface Opacity")
|
||||
settingLabel: I18n.tr("Transparency")
|
||||
reason: I18n.tr("Managed by Frame in Connected Mode")
|
||||
}
|
||||
|
||||
@@ -1647,8 +1647,8 @@ Item {
|
||||
tab: "theme"
|
||||
tags: ["surface", "popup", "transparency", "opacity", "modal"]
|
||||
settingKey: "popupTransparency"
|
||||
text: I18n.tr("Surface Opacity")
|
||||
description: I18n.tr("Controls opacity of shell surfaces, popouts, and modals")
|
||||
text: I18n.tr("Transparency")
|
||||
description: I18n.tr("Controls opacity of all popouts, modals, and their content layers")
|
||||
visible: !themeColorsTab.connectedFrameModeActive
|
||||
value: Math.round(SettingsData.popupTransparency * 100)
|
||||
minimum: 0
|
||||
@@ -1671,113 +1671,6 @@ Item {
|
||||
defaultValue: 12
|
||||
onSliderValueChanged: newValue => SettingsData.setCornerRadius(newValue)
|
||||
}
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
tab: "theme"
|
||||
tags: ["blur", "background", "transparency", "glass", "frosted"]
|
||||
title: I18n.tr("Background Blur")
|
||||
settingKey: "blurEnabled"
|
||||
iconName: "blur_on"
|
||||
|
||||
SettingsToggleRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "background", "transparency", "glass", "frosted"]
|
||||
settingKey: "blurEnabled"
|
||||
text: I18n.tr("Background Blur")
|
||||
description: !BlurService.available ? I18n.tr("Your compositor does not support background blur (ext-background-effect-v1)") : I18n.tr("Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.")
|
||||
checked: SettingsData.blurEnabled ?? false
|
||||
enabled: BlurService.available
|
||||
onToggled: checked => SettingsData.set("blurEnabled", checked)
|
||||
}
|
||||
|
||||
SettingsToggleRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "foreground", "layers", "contrast", "glass", "frosted"]
|
||||
settingKey: "blurForegroundLayers"
|
||||
text: I18n.tr("Foreground Layers")
|
||||
description: I18n.tr("Show foreground surfaces on blurred panels for stronger contrast")
|
||||
checked: SettingsData.blurForegroundLayers ?? true
|
||||
visible: BlurService.available && (SettingsData.blurEnabled ?? false)
|
||||
enabled: BlurService.available
|
||||
onToggled: checked => SettingsData.set("blurForegroundLayers", checked)
|
||||
}
|
||||
|
||||
SettingsSliderRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "foreground", "layers", "outline", "border", "cards", "widgets", "notifications", "control center"]
|
||||
settingKey: "blurLayerOutlineOpacity"
|
||||
text: I18n.tr("Layer Outline Opacity")
|
||||
description: I18n.tr("Controls outlines around blurred foreground cards, pills, and notification cards")
|
||||
visible: BlurService.available && (SettingsData.blurEnabled ?? false)
|
||||
value: Math.round((SettingsData.blurLayerOutlineOpacity ?? 0.12) * 100)
|
||||
minimum: 0
|
||||
maximum: 40
|
||||
unit: "%"
|
||||
defaultValue: 12
|
||||
onSliderValueChanged: newValue => SettingsData.set("blurLayerOutlineOpacity", newValue / 100)
|
||||
}
|
||||
|
||||
SettingsDropdownRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "border", "outline", "edge"]
|
||||
settingKey: "blurBorderColor"
|
||||
text: I18n.tr("Blur Border Color")
|
||||
description: I18n.tr("Border color around blurred surfaces")
|
||||
visible: SettingsData.blurEnabled
|
||||
options: [I18n.tr("Outline", "blur border color"), I18n.tr("Primary", "blur border color"), I18n.tr("Secondary", "blur border color"), I18n.tr("Text Color", "blur border color"), I18n.tr("Custom", "blur border color")]
|
||||
currentValue: {
|
||||
switch (SettingsData.blurBorderColor) {
|
||||
case "primary":
|
||||
return I18n.tr("Primary", "blur border color");
|
||||
case "secondary":
|
||||
return I18n.tr("Secondary", "blur border color");
|
||||
case "surfaceText":
|
||||
return I18n.tr("Text Color", "blur border color");
|
||||
case "custom":
|
||||
return I18n.tr("Custom", "blur border color");
|
||||
default:
|
||||
return I18n.tr("Outline", "blur border color");
|
||||
}
|
||||
}
|
||||
onValueChanged: value => {
|
||||
if (value === I18n.tr("Primary", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "primary");
|
||||
} else if (value === I18n.tr("Secondary", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "secondary");
|
||||
} else if (value === I18n.tr("Text Color", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "surfaceText");
|
||||
} else if (value === I18n.tr("Custom", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "custom");
|
||||
openBlurBorderColorPicker();
|
||||
} else {
|
||||
SettingsData.set("blurBorderColor", "outline");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
SettingsSliderRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "border", "opacity"]
|
||||
settingKey: "blurBorderOpacity"
|
||||
text: I18n.tr("Blur Border Opacity")
|
||||
description: I18n.tr("Controls the outer edge of protocol-blurred windows")
|
||||
visible: SettingsData.blurEnabled
|
||||
value: Math.round((SettingsData.blurBorderOpacity ?? 0.35) * 100)
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: "%"
|
||||
defaultValue: 35
|
||||
onSliderValueChanged: newValue => SettingsData.set("blurBorderOpacity", newValue / 100)
|
||||
}
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
tab: "theme"
|
||||
tags: ["elevation", "shadow", "lift", "m3", "material"]
|
||||
title: I18n.tr("Shadows")
|
||||
settingKey: "m3ElevationEnabled"
|
||||
iconName: "layers"
|
||||
|
||||
SettingsToggleRow {
|
||||
tab: "theme"
|
||||
@@ -1809,7 +1702,7 @@ Item {
|
||||
tags: ["elevation", "shadow", "opacity", "transparency", "m3"]
|
||||
settingKey: "m3ElevationOpacity"
|
||||
text: I18n.tr("Shadow Opacity")
|
||||
description: I18n.tr("Controls the opacity of the shadow")
|
||||
description: I18n.tr("Controls the transparency of the shadow")
|
||||
value: SettingsData.m3ElevationOpacity ?? 30
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
@@ -1963,6 +1856,105 @@ Item {
|
||||
}
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
tab: "theme"
|
||||
tags: ["blur", "background", "transparency", "glass", "frosted"]
|
||||
title: I18n.tr("Background Blur")
|
||||
settingKey: "blurEnabled"
|
||||
iconName: "blur_on"
|
||||
|
||||
SettingsToggleRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "background", "transparency", "glass", "frosted"]
|
||||
settingKey: "blurEnabled"
|
||||
text: I18n.tr("Background Blur")
|
||||
description: !BlurService.available ? I18n.tr("Your compositor does not support background blur (ext-background-effect-v1)") : I18n.tr("Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.")
|
||||
checked: SettingsData.blurEnabled ?? false
|
||||
enabled: BlurService.available
|
||||
onToggled: checked => SettingsData.set("blurEnabled", checked)
|
||||
}
|
||||
|
||||
SettingsToggleRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "foreground", "layers", "contrast", "glass", "frosted"]
|
||||
settingKey: "blurForegroundLayers"
|
||||
text: I18n.tr("Foreground Layers")
|
||||
description: I18n.tr("Show foreground surfaces on blurred panels for stronger contrast")
|
||||
checked: SettingsData.blurForegroundLayers ?? true
|
||||
visible: BlurService.available && (SettingsData.blurEnabled ?? false)
|
||||
enabled: BlurService.available
|
||||
onToggled: checked => SettingsData.set("blurForegroundLayers", checked)
|
||||
}
|
||||
|
||||
SettingsSliderRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "foreground", "layers", "outline", "border", "cards", "widgets", "notifications", "control center"]
|
||||
settingKey: "blurLayerOutlineOpacity"
|
||||
text: I18n.tr("Layer Outline Opacity")
|
||||
description: I18n.tr("Controls outlines around blurred foreground cards, pills, and notification cards")
|
||||
visible: BlurService.available && (SettingsData.blurEnabled ?? false)
|
||||
value: Math.round((SettingsData.blurLayerOutlineOpacity ?? 0.12) * 100)
|
||||
minimum: 0
|
||||
maximum: 40
|
||||
unit: "%"
|
||||
defaultValue: 12
|
||||
onSliderValueChanged: newValue => SettingsData.set("blurLayerOutlineOpacity", newValue / 100)
|
||||
}
|
||||
|
||||
SettingsDropdownRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "border", "outline", "edge"]
|
||||
settingKey: "blurBorderColor"
|
||||
text: I18n.tr("Blur Border Color")
|
||||
description: I18n.tr("Border color around blurred surfaces")
|
||||
visible: SettingsData.blurEnabled
|
||||
options: [I18n.tr("Outline", "blur border color"), I18n.tr("Primary", "blur border color"), I18n.tr("Secondary", "blur border color"), I18n.tr("Text Color", "blur border color"), I18n.tr("Custom", "blur border color")]
|
||||
currentValue: {
|
||||
switch (SettingsData.blurBorderColor) {
|
||||
case "primary":
|
||||
return I18n.tr("Primary", "blur border color");
|
||||
case "secondary":
|
||||
return I18n.tr("Secondary", "blur border color");
|
||||
case "surfaceText":
|
||||
return I18n.tr("Text Color", "blur border color");
|
||||
case "custom":
|
||||
return I18n.tr("Custom", "blur border color");
|
||||
default:
|
||||
return I18n.tr("Outline", "blur border color");
|
||||
}
|
||||
}
|
||||
onValueChanged: value => {
|
||||
if (value === I18n.tr("Primary", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "primary");
|
||||
} else if (value === I18n.tr("Secondary", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "secondary");
|
||||
} else if (value === I18n.tr("Text Color", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "surfaceText");
|
||||
} else if (value === I18n.tr("Custom", "blur border color")) {
|
||||
SettingsData.set("blurBorderColor", "custom");
|
||||
openBlurBorderColorPicker();
|
||||
} else {
|
||||
SettingsData.set("blurBorderColor", "outline");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
SettingsSliderRow {
|
||||
tab: "theme"
|
||||
tags: ["blur", "border", "opacity"]
|
||||
settingKey: "blurBorderOpacity"
|
||||
text: I18n.tr("Blur Border Opacity")
|
||||
description: I18n.tr("Controls the outer edge of protocol-blurred windows")
|
||||
visible: SettingsData.blurEnabled
|
||||
value: Math.round((SettingsData.blurBorderOpacity ?? 0.35) * 100)
|
||||
minimum: 0
|
||||
maximum: 100
|
||||
unit: "%"
|
||||
defaultValue: 35
|
||||
onSliderValueChanged: newValue => SettingsData.set("blurBorderOpacity", newValue / 100)
|
||||
}
|
||||
}
|
||||
|
||||
SettingsCard {
|
||||
tab: "theme"
|
||||
tags: ["modal", "darken", "background", "overlay"]
|
||||
|
||||
@@ -115,34 +115,6 @@ Item {
|
||||
}
|
||||
}
|
||||
|
||||
SettingsDropdownRow {
|
||||
tab: "time"
|
||||
tags: ["calendar", "backend", "daemon", "khal", "dankcalendar", "events"]
|
||||
settingKey: "calendarBackend"
|
||||
text: I18n.tr("Calendar Backend")
|
||||
description: {
|
||||
const resolved = CalendarService.activeBackend;
|
||||
switch (resolved) {
|
||||
case "dankcal":
|
||||
return I18n.tr("Using DankCalendar%1", "calendar backend status").arg(CalendarService.isDankActive && CalendarService.calendars.length > 0 ? "" : " (connecting…)");
|
||||
case "khal":
|
||||
return I18n.tr("Using khal", "calendar backend status");
|
||||
default:
|
||||
return I18n.tr("No calendar source available", "calendar backend status");
|
||||
}
|
||||
}
|
||||
readonly property var _backendValues: ["auto", "khal", "dankcal"]
|
||||
readonly property var _backendLabels: [I18n.tr("Auto", "calendar backend option"), I18n.tr("khal", "calendar backend option"), I18n.tr("DankCalendar", "calendar backend option")]
|
||||
options: _backendLabels
|
||||
currentValue: _backendLabels[Math.max(0, _backendValues.indexOf(SettingsData.calendarBackend))]
|
||||
onValueChanged: value => {
|
||||
const idx = _backendLabels.indexOf(value);
|
||||
if (idx < 0)
|
||||
return;
|
||||
SettingsData.set("calendarBackend", _backendValues[idx]);
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 1
|
||||
|
||||
@@ -64,8 +64,6 @@ Item {
|
||||
|
||||
property alias model: buttonGroup.model
|
||||
property alias currentIndex: buttonGroup.currentIndex
|
||||
property alias initialSelection: buttonGroup.initialSelection
|
||||
property alias currentSelection: buttonGroup.currentSelection
|
||||
property alias selectionMode: buttonGroup.selectionMode
|
||||
property alias buttonHeight: buttonGroup.buttonHeight
|
||||
property alias minButtonWidth: buttonGroup.minButtonWidth
|
||||
|
||||
@@ -460,7 +460,7 @@ Item {
|
||||
"id": widget.id,
|
||||
"enabled": widget.enabled
|
||||
};
|
||||
var keys = ["size", "selectedGpuIndex", "pciId", "mountPath", "diskUsageMode", "minimumWidth", "showSwap", "showInGb", "mediaSize", "clockCompactMode", "focusedWindowSize", "focusedWindowCompactMode", "runningAppsCompactMode", "keyboardLayoutNameCompactMode", "keyboardLayoutNameShowIcon", "runningAppsGroupByApp", "runningAppsCurrentWorkspace", "runningAppsCurrentMonitor", "showNetworkIcon", "showBluetoothIcon", "showAudioIcon", "showAudioPercent", "showVpnIcon", "showBrightnessIcon", "showBrightnessPercent", "showMicIcon", "showMicPercent", "showBatteryIcon", "showPrinterIcon", "showScreenSharingIcon", "showIdleInhibitorIcon", "showDoNotDisturbIcon", "controlCenterGroupOrder", "barMaxVisibleApps", "barMaxVisibleRunningApps", "barShowOverflowBadge", "trayUseInlineExpansion", "trayPopupSingleLine", "trayAutoOverflow", "trayMaxVisibleItems", "hideWhenIdle"];
|
||||
var keys = ["size", "selectedGpuIndex", "pciId", "mountPath", "diskUsageMode", "minimumWidth", "showSwap", "showInGb", "mediaSize", "clockCompactMode", "focusedWindowSize", "focusedWindowCompactMode", "runningAppsCompactMode", "keyboardLayoutNameCompactMode", "keyboardLayoutNameShowIcon", "runningAppsGroupByApp", "runningAppsCurrentWorkspace", "runningAppsCurrentMonitor", "showNetworkIcon", "showBluetoothIcon", "showAudioIcon", "showAudioPercent", "showVpnIcon", "showBrightnessIcon", "showBrightnessPercent", "showMicIcon", "showMicPercent", "showBatteryIcon", "showPrinterIcon", "showScreenSharingIcon", "showIdleInhibitorIcon", "showDoNotDisturbIcon", "controlCenterGroupOrder", "barMaxVisibleApps", "barMaxVisibleRunningApps", "barShowOverflowBadge", "trayUseInlineExpansion", "hideWhenIdle"];
|
||||
for (var i = 0; i < keys.length; i++) {
|
||||
if (widget[keys[i]] !== undefined)
|
||||
result[keys[i]] = widget[keys[i]];
|
||||
@@ -803,12 +803,6 @@ Item {
|
||||
item.barShowOverflowBadge = widget.barShowOverflowBadge;
|
||||
if (widget.trayUseInlineExpansion !== undefined)
|
||||
item.trayUseInlineExpansion = widget.trayUseInlineExpansion;
|
||||
if (widget.trayPopupSingleLine !== undefined)
|
||||
item.trayPopupSingleLine = widget.trayPopupSingleLine;
|
||||
if (widget.trayAutoOverflow !== undefined)
|
||||
item.trayAutoOverflow = widget.trayAutoOverflow;
|
||||
if (widget.trayMaxVisibleItems !== undefined)
|
||||
item.trayMaxVisibleItems = widget.trayMaxVisibleItems;
|
||||
if (widget.hideWhenIdle !== undefined)
|
||||
item.hideWhenIdle = widget.hideWhenIdle;
|
||||
}
|
||||
|
||||
@@ -43,7 +43,7 @@ Column {
|
||||
"id": widget.id,
|
||||
"enabled": widget.enabled
|
||||
};
|
||||
var keys = ["size", "selectedGpuIndex", "pciId", "mountPath", "diskUsageMode", "minimumWidth", "showSwap", "showInGb", "mediaSize", "clockCompactMode", "focusedWindowSize", "focusedWindowCompactMode", "runningAppsCompactMode", "keyboardLayoutNameCompactMode", "keyboardLayoutNameShowIcon", "runningAppsGroupByApp", "runningAppsCurrentWorkspace", "runningAppsCurrentMonitor", "showNetworkIcon", "showBluetoothIcon", "showAudioIcon", "showAudioPercent", "showVpnIcon", "showBrightnessIcon", "showBrightnessPercent", "showMicIcon", "showMicPercent", "showBatteryIcon", "showPrinterIcon", "showScreenSharingIcon", "showIdleInhibitorIcon", "showDoNotDisturbIcon", "controlCenterGroupOrder", "barMaxVisibleApps", "barMaxVisibleRunningApps", "barShowOverflowBadge", "trayUseInlineExpansion", "trayPopupSingleLine", "trayAutoOverflow", "trayMaxVisibleItems"];
|
||||
var keys = ["size", "selectedGpuIndex", "pciId", "mountPath", "diskUsageMode", "minimumWidth", "showSwap", "showInGb", "mediaSize", "clockCompactMode", "focusedWindowSize", "focusedWindowCompactMode", "runningAppsCompactMode", "keyboardLayoutNameCompactMode", "keyboardLayoutNameShowIcon", "runningAppsGroupByApp", "runningAppsCurrentWorkspace", "runningAppsCurrentMonitor", "showNetworkIcon", "showBluetoothIcon", "showAudioIcon", "showAudioPercent", "showVpnIcon", "showBrightnessIcon", "showBrightnessPercent", "showMicIcon", "showMicPercent", "showBatteryIcon", "showPrinterIcon", "showScreenSharingIcon", "showIdleInhibitorIcon", "showDoNotDisturbIcon", "controlCenterGroupOrder", "barMaxVisibleApps", "barMaxVisibleRunningApps", "barShowOverflowBadge", "trayUseInlineExpansion"];
|
||||
for (var i = 0; i < keys.length; i++) {
|
||||
if (widget[keys[i]] !== undefined)
|
||||
result[keys[i]] = widget[keys[i]];
|
||||
@@ -1126,188 +1126,6 @@ Column {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 32
|
||||
radius: Theme.cornerRadius
|
||||
color: trayPopupLineArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.12) : "transparent"
|
||||
opacity: (trayContextMenu.currentWidgetData?.trayUseInlineExpansion ?? false) ? 0.55 : 1
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "view_week"
|
||||
size: 16
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Single-Line Popup")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Normal
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
id: trayPopupLineToggle
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
width: 40
|
||||
height: 20
|
||||
checked: trayContextMenu.currentWidgetData?.trayPopupSingleLine ?? SettingsData.trayPopupSingleLine
|
||||
enabled: !(trayContextMenu.currentWidgetData?.trayUseInlineExpansion ?? false)
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: trayPopupLineArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: (trayContextMenu.currentWidgetData?.trayUseInlineExpansion ?? false) ? Qt.ArrowCursor : Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (trayContextMenu.currentWidgetData?.trayUseInlineExpansion ?? false)
|
||||
return;
|
||||
const newValue = !(trayContextMenu.currentWidgetData?.trayPopupSingleLine ?? SettingsData.trayPopupSingleLine);
|
||||
root.overflowSettingChanged(trayContextMenu.sectionId, trayContextMenu.widgetIndex, "trayPopupSingleLine", newValue);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 32
|
||||
radius: Theme.cornerRadius
|
||||
color: trayAutoOverflowArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.12) : "transparent"
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "responsive_layout"
|
||||
size: 16
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Auto Overflow")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Normal
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
DankToggle {
|
||||
id: trayAutoOverflowToggle
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
width: 40
|
||||
height: 20
|
||||
checked: trayContextMenu.currentWidgetData?.trayAutoOverflow ?? SettingsData.trayAutoOverflow
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: trayAutoOverflowArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
const newValue = !(trayContextMenu.currentWidgetData?.trayAutoOverflow ?? SettingsData.trayAutoOverflow);
|
||||
root.overflowSettingChanged(trayContextMenu.sectionId, trayContextMenu.widgetIndex, "trayAutoOverflow", newValue);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: parent.width
|
||||
height: 36
|
||||
radius: Theme.cornerRadius
|
||||
color: trayMaxVisibleArea.containsMouse ? Qt.rgba(Theme.primary.r, Theme.primary.g, Theme.primary.b, 0.12) : "transparent"
|
||||
opacity: (trayContextMenu.currentWidgetData?.trayAutoOverflow ?? SettingsData.trayAutoOverflow) ? 1 : 0.55
|
||||
|
||||
Row {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: Theme.spacingS
|
||||
|
||||
DankIcon {
|
||||
name: "low_priority"
|
||||
size: 16
|
||||
color: Theme.surfaceText
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: I18n.tr("Max Visible")
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceText
|
||||
font.weight: Font.Normal
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: {
|
||||
const value = trayContextMenu.currentWidgetData?.trayMaxVisibleItems ?? SettingsData.trayMaxVisibleItems;
|
||||
return value > 0 ? String(value) : I18n.tr("Auto");
|
||||
}
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: Theme.surfaceTextMedium
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
}
|
||||
}
|
||||
|
||||
Row {
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: Theme.spacingXS
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
spacing: 2
|
||||
|
||||
DankActionButton {
|
||||
buttonSize: 28
|
||||
iconName: "remove"
|
||||
iconSize: 16
|
||||
iconColor: Theme.surfaceText
|
||||
enabled: trayContextMenu.currentWidgetData?.trayAutoOverflow ?? SettingsData.trayAutoOverflow
|
||||
onClicked: {
|
||||
const current = trayContextMenu.currentWidgetData?.trayMaxVisibleItems ?? SettingsData.trayMaxVisibleItems;
|
||||
root.overflowSettingChanged(trayContextMenu.sectionId, trayContextMenu.widgetIndex, "trayMaxVisibleItems", Math.max(0, current - 1));
|
||||
}
|
||||
}
|
||||
|
||||
DankActionButton {
|
||||
buttonSize: 28
|
||||
iconName: "add"
|
||||
iconSize: 16
|
||||
iconColor: Theme.surfaceText
|
||||
enabled: trayContextMenu.currentWidgetData?.trayAutoOverflow ?? SettingsData.trayAutoOverflow
|
||||
onClicked: {
|
||||
const current = trayContextMenu.currentWidgetData?.trayMaxVisibleItems ?? SettingsData.trayMaxVisibleItems;
|
||||
root.overflowSettingChanged(trayContextMenu.sectionId, trayContextMenu.widgetIndex, "trayMaxVisibleItems", Math.min(20, current + 1));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: trayMaxVisibleArea
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
acceptedButtons: Qt.NoButton
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -32,8 +32,6 @@ Variants {
|
||||
|
||||
color: "transparent"
|
||||
|
||||
updatesEnabled: root.renderActive || root._settleFrames > 0
|
||||
|
||||
mask: Region {
|
||||
item: Item {}
|
||||
}
|
||||
@@ -86,59 +84,20 @@ Variants {
|
||||
|
||||
readonly property bool transitioning: transitionAnimation.running
|
||||
property bool effectActive: false
|
||||
property bool _renderSettling: true
|
||||
property bool _overviewBlurSettling: false
|
||||
property bool useNextForEffect: false
|
||||
property string pendingWallpaper: ""
|
||||
property string _deferredSource: ""
|
||||
readonly property bool overviewBlurActive: CompositorService.isNiri && SettingsData.blurWallpaperOnOverview && NiriService.inOverview && currentWallpaper.source !== ""
|
||||
readonly property var backingWindow: Window.window
|
||||
readonly property bool renderActive: !source || effectActive || overviewBlurActive || pendingWallpaper !== "" || _deferredSource !== "" || currentWallpaper.status === Image.Loading || nextWallpaper.status === Image.Loading
|
||||
property int _settleFrames: 3
|
||||
|
||||
function invalidate() {
|
||||
_settleFrames = 3;
|
||||
backingWindow?.update();
|
||||
}
|
||||
|
||||
onRenderActiveChanged: invalidate()
|
||||
onBackingWindowChanged: invalidate()
|
||||
|
||||
Connections {
|
||||
target: root.backingWindow
|
||||
function onFrameSwapped() {
|
||||
if (root._settleFrames > 0)
|
||||
root._settleFrames--;
|
||||
}
|
||||
function onVisibleChanged() {
|
||||
root.invalidate();
|
||||
}
|
||||
function onWidthChanged() {
|
||||
root.invalidate();
|
||||
}
|
||||
function onHeightChanged() {
|
||||
root.invalidate();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: Quickshell
|
||||
function onScreensChanged() {
|
||||
root.invalidate();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: SettingsData
|
||||
function onWallpaperFillModeChanged() {
|
||||
root.invalidate();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: IdleService
|
||||
function onIsShellLockedChanged() {
|
||||
if (IdleService.isShellLocked)
|
||||
target: currentWallpaper
|
||||
function onStatusChanged() {
|
||||
if (currentWallpaper.status !== Image.Ready && currentWallpaper.status !== Image.Error)
|
||||
return;
|
||||
root.invalidate();
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -150,11 +109,32 @@ Variants {
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: wallpaperWindow
|
||||
function onWidthChanged() {
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
function onHeightChanged() {
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: Quickshell
|
||||
function onScreensChanged() {
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: NiriService
|
||||
function onDisplayScalesChanged() {
|
||||
root._recheckScreenScale();
|
||||
root.invalidate();
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -162,7 +142,29 @@ Variants {
|
||||
target: WlrOutputService
|
||||
function onWlrOutputAvailableChanged() {
|
||||
root._recheckScreenScale();
|
||||
root.invalidate();
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: NiriService
|
||||
function onInOverviewChanged() {
|
||||
root._overviewBlurSettling = true;
|
||||
overviewBlurSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: SettingsData
|
||||
function onBlurWallpaperOnOverviewChanged() {
|
||||
root._overviewBlurSettling = true;
|
||||
overviewBlurSettleTimer.restart();
|
||||
}
|
||||
|
||||
function onWallpaperFillModeChanged() {
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -179,22 +181,26 @@ Variants {
|
||||
}
|
||||
}
|
||||
|
||||
function handleTransitionLoadError(failedSource) {
|
||||
log.warn("failed to load candidate wallpaper for", modelData.name + ":", failedSource);
|
||||
transitionDelayTimer.stop();
|
||||
transitionAnimation.stop();
|
||||
root.useNextForEffect = false;
|
||||
root.effectActive = false;
|
||||
root.transitionProgress = 0.0;
|
||||
currentWallpaper.layer.enabled = false;
|
||||
nextWallpaper.layer.enabled = false;
|
||||
nextWallpaper.source = "";
|
||||
Connections {
|
||||
target: IdleService
|
||||
function onIsShellLockedChanged() {
|
||||
if (!IdleService.isShellLocked) {
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!root.pendingWallpaper)
|
||||
return;
|
||||
const pending = root.pendingWallpaper;
|
||||
root.pendingWallpaper = "";
|
||||
Qt.callLater(() => root.changeWallpaper(pending, true));
|
||||
Timer {
|
||||
id: renderSettleTimer
|
||||
interval: 1000
|
||||
onTriggered: root._renderSettling = false
|
||||
}
|
||||
|
||||
Timer {
|
||||
id: overviewBlurSettleTimer
|
||||
interval: 150
|
||||
onTriggered: root._overviewBlurSettling = false
|
||||
}
|
||||
|
||||
function getFillMode(modeName) {
|
||||
@@ -221,6 +227,11 @@ Variants {
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
wallpaperWindow.updatesEnabled = Qt.binding(() => !root.source || root.effectActive || root._renderSettling || root.overviewBlurActive || root._overviewBlurSettling || root.pendingWallpaper !== "" || root._deferredSource !== "" || currentWallpaper.status === Image.Loading || nextWallpaper.status === Image.Loading);
|
||||
|
||||
if (!source) {
|
||||
root._renderSettling = false;
|
||||
}
|
||||
isInitialized = true;
|
||||
}
|
||||
|
||||
@@ -251,6 +262,8 @@ Variants {
|
||||
transitionAnimation.stop();
|
||||
root.transitionProgress = 0.0;
|
||||
root.effectActive = false;
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
root.screenScale = CompositorService.getScreenScale(modelData);
|
||||
currentWallpaper.source = newSource;
|
||||
nextWallpaper.source = "";
|
||||
@@ -315,6 +328,9 @@ Variants {
|
||||
break;
|
||||
}
|
||||
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
|
||||
nextWallpaper.source = newPath;
|
||||
|
||||
if (nextWallpaper.status === Image.Ready)
|
||||
@@ -323,7 +339,7 @@ Variants {
|
||||
|
||||
Loader {
|
||||
anchors.fill: parent
|
||||
active: !root.source || root.isColorSource || currentWallpaper.status === Image.Error
|
||||
active: !root.source || root.isColorSource
|
||||
asynchronous: true
|
||||
|
||||
sourceComponent: DankBackdrop {
|
||||
@@ -348,12 +364,6 @@ Variants {
|
||||
cache: true
|
||||
sourceSize: Qt.size(root.textureWidth, root.textureHeight)
|
||||
fillMode: root.getFillMode(SessionData.getMonitorWallpaperFillMode(modelData.name))
|
||||
|
||||
onStatusChanged: {
|
||||
if (status === Image.Error) {
|
||||
log.warn("failed to load active wallpaper for", modelData.name + ":", source);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Image {
|
||||
@@ -370,13 +380,11 @@ Variants {
|
||||
fillMode: root.getFillMode(SessionData.getMonitorWallpaperFillMode(modelData.name))
|
||||
|
||||
onStatusChanged: {
|
||||
if (status === Image.Error) {
|
||||
root.handleTransitionLoadError(source);
|
||||
return;
|
||||
}
|
||||
if (status !== Image.Ready)
|
||||
return;
|
||||
if (root.actualTransitionType === "none") {
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
currentWallpaper.source = source;
|
||||
nextWallpaper.source = "";
|
||||
root.transitionProgress = 0.0;
|
||||
@@ -624,6 +632,8 @@ Variants {
|
||||
root.transitionProgress = 0.0;
|
||||
currentWallpaper.layer.enabled = false;
|
||||
nextWallpaper.layer.enabled = false;
|
||||
root._renderSettling = true;
|
||||
renderSettleTimer.restart();
|
||||
root.effectActive = false;
|
||||
|
||||
if (!root.pendingWallpaper)
|
||||
|
||||
@@ -58,8 +58,6 @@ Singleton {
|
||||
return SessionData.deviceMaxVolumes[name] ?? 100;
|
||||
}
|
||||
|
||||
readonly property int wheelVolumeStep: SettingsData.audioWheelScrollAmount
|
||||
|
||||
signal micMuteChanged
|
||||
signal audioOutputCycled(string deviceName, string deviceIcon)
|
||||
signal deviceAliasChanged(string nodeName, string newAlias)
|
||||
@@ -158,19 +156,14 @@ Singleton {
|
||||
return false;
|
||||
}
|
||||
|
||||
function cycleAudioOutputDirection(forward) {
|
||||
function cycleAudioOutput() {
|
||||
const sinks = getAvailableSinks();
|
||||
if (sinks.length < 2)
|
||||
return null;
|
||||
|
||||
const currentName = root.sink?.name ?? "";
|
||||
const currentIndex = sinks.findIndex(s => s.name === currentName);
|
||||
let nextIndex;
|
||||
if (forward) {
|
||||
nextIndex = (currentIndex + 1) % sinks.length;
|
||||
} else {
|
||||
nextIndex = (currentIndex - 1 + sinks.length) % sinks.length;
|
||||
}
|
||||
const nextIndex = (currentIndex + 1) % sinks.length;
|
||||
const nextSink = sinks[nextIndex];
|
||||
setDefaultSinkByName(nextSink.name);
|
||||
const name = displayName(nextSink);
|
||||
@@ -178,10 +171,6 @@ Singleton {
|
||||
return name;
|
||||
}
|
||||
|
||||
function cycleAudioOutput() {
|
||||
return cycleAudioOutputDirection(true);
|
||||
}
|
||||
|
||||
function getDeviceAlias(nodeName) {
|
||||
if (!nodeName)
|
||||
return null;
|
||||
@@ -844,28 +833,6 @@ EOFCONFIG
|
||||
return root.sink.audio.muted ? "Audio muted" : "Audio unmuted";
|
||||
}
|
||||
|
||||
function handleNodeVolumeWheel(node, wheelEvent) {
|
||||
if (!node?.audio)
|
||||
return;
|
||||
|
||||
SessionData.suppressOSDTemporarily();
|
||||
const delta = wheelEvent.angleDelta.y;
|
||||
if (delta === 0)
|
||||
return;
|
||||
|
||||
const current = Math.round(node.audio.volume * 100);
|
||||
const maxVol = getMaxVolumePercent(node);
|
||||
const newVolume = delta > 0 ? Math.min(maxVol, current + root.wheelVolumeStep) : Math.max(0, current - root.wheelVolumeStep);
|
||||
|
||||
node.audio.muted = false;
|
||||
node.audio.volume = newVolume / 100;
|
||||
|
||||
if (node === sink) {
|
||||
playVolumeChangeSoundIfEnabled();
|
||||
}
|
||||
wheelEvent.accepted = true;
|
||||
}
|
||||
|
||||
function setMicVolume(percentage) {
|
||||
if (!root.source?.audio) {
|
||||
return "No audio source available";
|
||||
|
||||
@@ -1,481 +0,0 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
|
||||
import QtQuick
|
||||
import Quickshell
|
||||
import Quickshell.Io
|
||||
import qs.Common
|
||||
import qs.Services
|
||||
|
||||
Item {
|
||||
id: root
|
||||
readonly property var log: Log.scoped("CalendarDankBackend")
|
||||
|
||||
property bool enabled: false
|
||||
|
||||
property string socketPath: ""
|
||||
readonly property bool socketFound: socketPath.length > 0
|
||||
property bool connected: false
|
||||
property bool binaryExists: false
|
||||
property bool binaryChecked: false
|
||||
|
||||
property var calendars: []
|
||||
property var events: []
|
||||
property var eventsByDate: ({})
|
||||
property string lastError: ""
|
||||
property date focusDate: new Date()
|
||||
property var _loadedFrom: null
|
||||
property var _loadedTo: null
|
||||
|
||||
property var pendingRequests: ({})
|
||||
property int requestCounter: 0
|
||||
|
||||
readonly property var fallbackPalette: ["#7287fd", "#f38ba8", "#a6e3a1", "#fab387", "#cba6f7", "#94e2d5", "#f9e2af", "#89dceb"]
|
||||
|
||||
signal eventsUpdated
|
||||
|
||||
onEnabledChanged: {
|
||||
if (enabled) {
|
||||
if (!connected)
|
||||
discoverProcess.running = true;
|
||||
return;
|
||||
}
|
||||
requestSocket.connected = false;
|
||||
subscribeSocket.connected = false;
|
||||
socketPath = "";
|
||||
connected = false;
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
binaryCheck.running = true;
|
||||
discoverProcess.running = true;
|
||||
}
|
||||
|
||||
Process {
|
||||
id: binaryCheck
|
||||
command: ["sh", "-c", "command -v dcal"]
|
||||
running: false
|
||||
onExited: code => {
|
||||
root.binaryExists = (code === 0);
|
||||
root.binaryChecked = true;
|
||||
}
|
||||
}
|
||||
|
||||
Process {
|
||||
id: discoverProcess
|
||||
running: false
|
||||
command: ["sh", "-c", "s=\"${DANKCAL_SOCKET:-}\"; if [ -S \"$s\" ]; then echo \"$s\"; exit 0; fi; for f in \"${XDG_RUNTIME_DIR:-/tmp}\"/dankcal-*.sock /tmp/dankcal-*.sock; do [ -S \"$f\" ] || continue; p=$(basename \"$f\" .sock); p=${p#dankcal-}; if kill -0 \"$p\" 2>/dev/null; then echo \"$f\"; exit 0; fi; done"]
|
||||
|
||||
stdout: StdioCollector {
|
||||
onStreamFinished: {
|
||||
const path = text.trim().split('\n')[0] || "";
|
||||
if (path.length > 0) {
|
||||
root._applySocketPath(path);
|
||||
return;
|
||||
}
|
||||
if (!root.connected) {
|
||||
if (root.socketPath !== "")
|
||||
root.log.info("dankcal socket gone, waiting for daemon");
|
||||
requestSocket.connected = false;
|
||||
subscribeSocket.connected = false;
|
||||
root.socketPath = "";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Timer {
|
||||
id: rediscoverTimer
|
||||
interval: 3000
|
||||
repeat: true
|
||||
running: root.enabled && !root.connected
|
||||
onTriggered: {
|
||||
if (!discoverProcess.running)
|
||||
discoverProcess.running = true;
|
||||
}
|
||||
}
|
||||
|
||||
function launch() {
|
||||
if (!binaryExists)
|
||||
return;
|
||||
Quickshell.execDetached(["dcal", "run", "-d", "--hidden"]);
|
||||
if (enabled && !connected)
|
||||
discoverProcess.running = true;
|
||||
}
|
||||
|
||||
function _applySocketPath(path) {
|
||||
const changed = path !== socketPath;
|
||||
if (changed)
|
||||
log.info("dankcal socket discovered:", path);
|
||||
if (!changed && connected)
|
||||
return;
|
||||
socketPath = path;
|
||||
_reconnect();
|
||||
}
|
||||
|
||||
function _reconnect() {
|
||||
requestSocket.connected = false;
|
||||
subscribeSocket.connected = false;
|
||||
Qt.callLater(() => requestSocket.connected = true);
|
||||
}
|
||||
|
||||
DankSocket {
|
||||
id: requestSocket
|
||||
path: root.socketPath
|
||||
connected: false
|
||||
|
||||
onConnectionStateChanged: {
|
||||
if (linkUp) {
|
||||
root.connected = true;
|
||||
subscribeSocket.connected = true;
|
||||
root.log.info("connected to dankcal:", root.socketPath);
|
||||
root.refreshCalendars();
|
||||
root.reloadEvents();
|
||||
return;
|
||||
}
|
||||
if (!root.connected && !root.socketFound)
|
||||
return;
|
||||
root.connected = false;
|
||||
root._flushPending();
|
||||
requestSocket.connected = false;
|
||||
subscribeSocket.connected = false;
|
||||
root.log.info("dankcal disconnected, rediscovering");
|
||||
if (root.enabled)
|
||||
discoverProcess.running = true;
|
||||
}
|
||||
|
||||
parser: SplitParser {
|
||||
onRead: line => {
|
||||
if (!line || line.length === 0)
|
||||
return;
|
||||
let response;
|
||||
try {
|
||||
response = JSON.parse(line);
|
||||
} catch (e) {
|
||||
return;
|
||||
}
|
||||
root._handleResponse(response);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DankSocket {
|
||||
id: subscribeSocket
|
||||
path: root.socketPath
|
||||
connected: false
|
||||
|
||||
onConnectionStateChanged: {
|
||||
if (linkUp)
|
||||
root._sendSubscribe();
|
||||
}
|
||||
|
||||
parser: SplitParser {
|
||||
onRead: line => {
|
||||
if (!line || line.length === 0)
|
||||
return;
|
||||
let event;
|
||||
try {
|
||||
event = JSON.parse(line);
|
||||
} catch (e) {
|
||||
return;
|
||||
}
|
||||
root._handleEvent(event);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Timer {
|
||||
id: refreshDebounce
|
||||
interval: 400
|
||||
repeat: false
|
||||
onTriggered: {
|
||||
root.refreshCalendars();
|
||||
root.reloadEvents();
|
||||
}
|
||||
}
|
||||
|
||||
function _sendSubscribe() {
|
||||
subscribeSocket.send({
|
||||
"id": _nextId(),
|
||||
"method": "subscribe",
|
||||
"params": {
|
||||
"topics": ["accounts", "calendars", "events", "sync"]
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function _nextId() {
|
||||
requestCounter++;
|
||||
return Date.now() + requestCounter;
|
||||
}
|
||||
|
||||
function _flushPending() {
|
||||
const ids = Object.keys(pendingRequests);
|
||||
for (const id of ids) {
|
||||
const cb = pendingRequests[id];
|
||||
delete pendingRequests[id];
|
||||
if (cb)
|
||||
cb({
|
||||
"error": "disconnected"
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
function _handleResponse(response) {
|
||||
if (response.event) {
|
||||
_handleEvent(response);
|
||||
return;
|
||||
}
|
||||
const id = response.id;
|
||||
if (!id)
|
||||
return;
|
||||
const cb = pendingRequests[id];
|
||||
if (cb) {
|
||||
delete pendingRequests[id];
|
||||
cb(response);
|
||||
}
|
||||
}
|
||||
|
||||
function _handleEvent(event) {
|
||||
switch (event.event) {
|
||||
case "accounts":
|
||||
case "calendars":
|
||||
refreshCalendars();
|
||||
refreshDebounce.restart();
|
||||
break;
|
||||
case "events":
|
||||
case "sync":
|
||||
refreshDebounce.restart();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function sendRequest(method, params, callback) {
|
||||
if (!connected) {
|
||||
if (callback)
|
||||
callback({
|
||||
"error": "not connected to dankcal socket"
|
||||
});
|
||||
return;
|
||||
}
|
||||
const id = _nextId();
|
||||
const req = {
|
||||
"id": id,
|
||||
"method": method
|
||||
};
|
||||
if (params)
|
||||
req.params = params;
|
||||
if (callback)
|
||||
pendingRequests[id] = callback;
|
||||
requestSocket.send(req);
|
||||
}
|
||||
|
||||
function refreshCalendars() {
|
||||
sendRequest("calendars.list", null, response => {
|
||||
if (response.error) {
|
||||
lastError = response.error;
|
||||
return;
|
||||
}
|
||||
const list = response.result || [];
|
||||
for (let i = 0; i < list.length; i++) {
|
||||
if (!list[i].color)
|
||||
list[i].color = fallbackPalette[i % fallbackPalette.length];
|
||||
}
|
||||
calendars = list;
|
||||
_rebuildEventsByDate();
|
||||
});
|
||||
}
|
||||
|
||||
function calendarById(id) {
|
||||
for (let i = 0; i < calendars.length; i++) {
|
||||
if (calendars[i].id === id)
|
||||
return calendars[i];
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
function writableCalendars() {
|
||||
return calendars.filter(c => !c.readOnly);
|
||||
}
|
||||
|
||||
function defaultCalendar() {
|
||||
const writable = writableCalendars().filter(c => !c.hidden);
|
||||
return writable.length > 0 ? writable[0] : null;
|
||||
}
|
||||
|
||||
function loadEvents(startDate, endDate) {
|
||||
const mid = new Date((startDate.getTime() + endDate.getTime()) / 2);
|
||||
focusDate = mid;
|
||||
_ensureWindow();
|
||||
}
|
||||
|
||||
function _ensureWindow() {
|
||||
if (!connected)
|
||||
return;
|
||||
if (!_loadedFrom || !_loadedTo) {
|
||||
reloadEvents();
|
||||
return;
|
||||
}
|
||||
const margin = 14 * 86400000;
|
||||
const t = focusDate.getTime();
|
||||
if (t < _loadedFrom.getTime() + margin || t > _loadedTo.getTime() - margin)
|
||||
reloadEvents();
|
||||
else
|
||||
_rebuildEventsByDate();
|
||||
}
|
||||
|
||||
function reloadEvents() {
|
||||
if (!connected)
|
||||
return;
|
||||
const from = new Date(focusDate.getTime() - 60 * 86400000);
|
||||
const to = new Date(focusDate.getTime() + 90 * 86400000);
|
||||
sendRequest("events.list", {
|
||||
"from": from.toISOString(),
|
||||
"to": to.toISOString(),
|
||||
"limit": 5000
|
||||
}, response => {
|
||||
if (response.error) {
|
||||
lastError = response.error;
|
||||
return;
|
||||
}
|
||||
_loadedFrom = from;
|
||||
_loadedTo = to;
|
||||
const raw = (response.result || {}).events || [];
|
||||
events = raw.map(e => _normalizeEvent(e));
|
||||
_rebuildEventsByDate();
|
||||
});
|
||||
}
|
||||
|
||||
function _dayBoundary(iso) {
|
||||
const d = new Date(iso);
|
||||
return new Date(d.getUTCFullYear(), d.getUTCMonth(), d.getUTCDate());
|
||||
}
|
||||
|
||||
function _normalizeEvent(e) {
|
||||
const allDay = !!e.allDay;
|
||||
const id = e.id || "";
|
||||
if (id.startsWith("task_"))
|
||||
log.warn("daemon event id collides with task prefix:", id);
|
||||
return {
|
||||
"id": id,
|
||||
"calendarId": e.calendarId || "",
|
||||
"title": e.summary || "(untitled)",
|
||||
"description": e.description || "",
|
||||
"location": e.location || "",
|
||||
"url": e.url || "",
|
||||
"start": allDay ? _dayBoundary(e.start) : new Date(e.start),
|
||||
"end": allDay ? _dayBoundary(e.end) : new Date(e.end),
|
||||
"allDay": allDay,
|
||||
"status": e.status || "confirmed",
|
||||
"recurringId": e.recurringId || "",
|
||||
"attendees": e.attendees || [],
|
||||
"organizer": e.organizer || null,
|
||||
"reminders": e.reminders || []
|
||||
};
|
||||
}
|
||||
|
||||
function decorateEvent(ev) {
|
||||
const cal = calendarById(ev.calendarId);
|
||||
const out = Object.assign({}, ev);
|
||||
out.color = cal ? cal.color : fallbackPalette[0];
|
||||
out.calendar = cal ? cal.name : "";
|
||||
out.account = cal ? (cal.accountName || cal.accountId || "") : "";
|
||||
out.readOnly = cal ? !!cal.readOnly : false;
|
||||
out.isMultiDay = ev.start.toDateString() !== ev.end.toDateString();
|
||||
return out;
|
||||
}
|
||||
|
||||
function _hiddenCalendarIds() {
|
||||
const hidden = {};
|
||||
for (let i = 0; i < calendars.length; i++) {
|
||||
if (calendars[i].hidden)
|
||||
hidden[calendars[i].id] = true;
|
||||
}
|
||||
return hidden;
|
||||
}
|
||||
|
||||
function _clampForDay(ev, cur, endDay) {
|
||||
const out = Object.assign({}, ev);
|
||||
const dayStart = new Date(cur.getFullYear(), cur.getMonth(), cur.getDate());
|
||||
const startDay = new Date(ev.start.getFullYear(), ev.start.getMonth(), ev.start.getDate());
|
||||
if (dayStart.getTime() === startDay.getTime()) {
|
||||
out.start = new Date(ev.start);
|
||||
} else {
|
||||
out.start = new Date(dayStart);
|
||||
if (!ev.allDay)
|
||||
out.start.setHours(0, 0, 0, 0);
|
||||
}
|
||||
if (dayStart.getTime() === endDay.getTime()) {
|
||||
out.end = new Date(ev.end);
|
||||
} else {
|
||||
out.end = new Date(dayStart);
|
||||
if (!ev.allDay)
|
||||
out.end.setHours(23, 59, 59, 999);
|
||||
}
|
||||
return out;
|
||||
}
|
||||
|
||||
function _rebuildEventsByDate() {
|
||||
const hidden = _hiddenCalendarIds();
|
||||
const map = {};
|
||||
for (const raw of events) {
|
||||
if (raw.status === "cancelled")
|
||||
continue;
|
||||
if (hidden[raw.calendarId])
|
||||
continue;
|
||||
const ev = decorateEvent(raw);
|
||||
const lastInstant = ev.allDay ? new Date(ev.end.getTime() - 1) : ev.end;
|
||||
let cur = new Date(ev.start.getFullYear(), ev.start.getMonth(), ev.start.getDate());
|
||||
let endDay = new Date(lastInstant.getFullYear(), lastInstant.getMonth(), lastInstant.getDate());
|
||||
if (endDay < cur)
|
||||
endDay = new Date(cur);
|
||||
while (cur <= endDay) {
|
||||
const key = Qt.formatDate(cur, "yyyy-MM-dd");
|
||||
if (!map[key])
|
||||
map[key] = [];
|
||||
if (!map[key].some(e => e.id === ev.id))
|
||||
map[key].push(_clampForDay(ev, cur, endDay));
|
||||
cur.setDate(cur.getDate() + 1);
|
||||
}
|
||||
}
|
||||
eventsByDate = map;
|
||||
eventsUpdated();
|
||||
}
|
||||
|
||||
function createEvent(fields, callback) {
|
||||
sendRequest("events.create", fields, response => {
|
||||
if (response.error)
|
||||
lastError = response.error;
|
||||
else
|
||||
reloadEvents();
|
||||
if (callback)
|
||||
callback(response);
|
||||
});
|
||||
}
|
||||
|
||||
function updateEvent(id, fields, callback) {
|
||||
const params = Object.assign({
|
||||
"id": id
|
||||
}, fields);
|
||||
sendRequest("events.update", params, response => {
|
||||
if (response.error)
|
||||
lastError = response.error;
|
||||
else
|
||||
reloadEvents();
|
||||
if (callback)
|
||||
callback(response);
|
||||
});
|
||||
}
|
||||
|
||||
function deleteEvent(id, callback) {
|
||||
sendRequest("events.delete", {
|
||||
"id": id
|
||||
}, response => {
|
||||
if (response.error)
|
||||
lastError = response.error;
|
||||
else
|
||||
reloadEvents();
|
||||
if (callback)
|
||||
callback(response);
|
||||
});
|
||||
}
|
||||
}
|
||||
@@ -1,237 +0,0 @@
|
||||
pragma ComponentBehavior: Bound
|
||||
|
||||
import QtQuick
|
||||
import Quickshell.Io
|
||||
import qs.Common
|
||||
import qs.Services
|
||||
|
||||
Item {
|
||||
id: root
|
||||
readonly property var log: Log.scoped("CalendarKhalBackend")
|
||||
|
||||
property bool installed: false
|
||||
property var eventsByDate: ({})
|
||||
property bool isLoading: false
|
||||
property string lastError: ""
|
||||
property date lastStartDate
|
||||
property date lastEndDate
|
||||
property string dateFormat: "MM/dd/yyyy"
|
||||
|
||||
function checkAvailability() {
|
||||
if (!formatProcess.running)
|
||||
formatProcess.running = true;
|
||||
}
|
||||
|
||||
function loadCurrentMonth() {
|
||||
let today = new Date();
|
||||
let firstDay = new Date(today.getFullYear(), today.getMonth(), 1);
|
||||
let lastDay = new Date(today.getFullYear(), today.getMonth() + 1, 0);
|
||||
let startDate = new Date(firstDay);
|
||||
startDate.setDate(startDate.getDate() - firstDay.getDay() - 7);
|
||||
let endDate = new Date(lastDay);
|
||||
endDate.setDate(endDate.getDate() + (6 - lastDay.getDay()) + 7);
|
||||
loadEvents(startDate, endDate);
|
||||
}
|
||||
|
||||
function loadEvents(startDate, endDate) {
|
||||
if (!installed)
|
||||
return;
|
||||
if (eventsProcess.running)
|
||||
return;
|
||||
root.lastStartDate = startDate;
|
||||
root.lastEndDate = endDate;
|
||||
root.isLoading = true;
|
||||
let startDateStr = Qt.formatDate(startDate, root.dateFormat);
|
||||
let endDateStr = Qt.formatDate(endDate, root.dateFormat);
|
||||
eventsProcess.requestStartDate = startDate;
|
||||
eventsProcess.requestEndDate = endDate;
|
||||
eventsProcess.command = ["khal", "list", "--json", "title", "--json", "description", "--json", "start-date", "--json", "start-time", "--json", "end-date", "--json", "end-time", "--json", "all-day", "--json", "location", "--json", "url", startDateStr, endDateStr];
|
||||
eventsProcess.running = true;
|
||||
}
|
||||
|
||||
function _parseDateFormat(formatExample) {
|
||||
return formatExample.replace("12", "MM").replace("21", "dd").replace("2013", "yyyy");
|
||||
}
|
||||
|
||||
Component.onCompleted: checkAvailability()
|
||||
|
||||
Process {
|
||||
id: formatProcess
|
||||
|
||||
command: ["khal", "printformats"]
|
||||
running: false
|
||||
onExited: exitCode => {
|
||||
if (exitCode !== 0)
|
||||
checkProcess.running = true;
|
||||
}
|
||||
|
||||
stdout: StdioCollector {
|
||||
onStreamFinished: {
|
||||
let lines = text.split('\n');
|
||||
for (let line of lines) {
|
||||
if (!line.startsWith('dateformat:'))
|
||||
continue;
|
||||
let formatExample = line.substring(line.indexOf(':') + 1).trim();
|
||||
root.dateFormat = root._parseDateFormat(formatExample);
|
||||
break;
|
||||
}
|
||||
checkProcess.running = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Process {
|
||||
id: checkProcess
|
||||
|
||||
command: ["khal", "list", "today"]
|
||||
running: false
|
||||
onExited: exitCode => {
|
||||
root.installed = (exitCode === 0);
|
||||
if (root.installed)
|
||||
root.loadCurrentMonth();
|
||||
}
|
||||
}
|
||||
|
||||
Process {
|
||||
id: eventsProcess
|
||||
|
||||
property date requestStartDate
|
||||
property date requestEndDate
|
||||
property string rawOutput: ""
|
||||
|
||||
running: false
|
||||
onExited: exitCode => {
|
||||
root.isLoading = false;
|
||||
if (exitCode !== 0) {
|
||||
root.lastError = "Failed to load events (exit code: " + exitCode + ")";
|
||||
return;
|
||||
}
|
||||
try {
|
||||
let newEventsByDate = {};
|
||||
let lines = eventsProcess.rawOutput.split('\n');
|
||||
for (let line of lines) {
|
||||
line = line.trim();
|
||||
if (!line || line === "[]")
|
||||
continue;
|
||||
|
||||
let dayEvents = JSON.parse(line);
|
||||
for (let event of dayEvents) {
|
||||
if (!event.title)
|
||||
continue;
|
||||
|
||||
let startDate, endDate;
|
||||
if (event['start-date'])
|
||||
startDate = Date.fromLocaleString(I18n.locale(), event['start-date'], root.dateFormat);
|
||||
else
|
||||
startDate = new Date();
|
||||
if (event['end-date'])
|
||||
endDate = Date.fromLocaleString(I18n.locale(), event['end-date'], root.dateFormat);
|
||||
else
|
||||
endDate = new Date(startDate);
|
||||
|
||||
let startTime = new Date(startDate);
|
||||
let endTime = new Date(endDate);
|
||||
if (event['start-time'] && event['all-day'] !== "True") {
|
||||
let timeStr = event['start-time'];
|
||||
if (timeStr) {
|
||||
let timeParts = timeStr.match(/(\d+):(\d+)(?::\d+)?\s*(AM|PM)?/i);
|
||||
if (timeParts) {
|
||||
let hours = parseInt(timeParts[1]);
|
||||
let minutes = parseInt(timeParts[2]);
|
||||
if (timeParts[3]) {
|
||||
let period = timeParts[3].toUpperCase();
|
||||
if (period === 'PM' && hours !== 12)
|
||||
hours += 12;
|
||||
else if (period === 'AM' && hours === 12)
|
||||
hours = 0;
|
||||
}
|
||||
startTime.setHours(hours, minutes);
|
||||
if (event['end-time']) {
|
||||
let endTimeParts = event['end-time'].match(/(\d+):(\d+)(?::\d+)?\s*(AM|PM)?/i);
|
||||
if (endTimeParts) {
|
||||
let endHours = parseInt(endTimeParts[1]);
|
||||
let endMinutes = parseInt(endTimeParts[2]);
|
||||
if (endTimeParts[3]) {
|
||||
let endPeriod = endTimeParts[3].toUpperCase();
|
||||
if (endPeriod === 'PM' && endHours !== 12)
|
||||
endHours += 12;
|
||||
else if (endPeriod === 'AM' && endHours === 12)
|
||||
endHours = 0;
|
||||
}
|
||||
endTime.setHours(endHours, endMinutes);
|
||||
}
|
||||
} else {
|
||||
endTime = new Date(startTime);
|
||||
endTime.setHours(startTime.getHours() + 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
let eventId = event.title + "_" + event['start-date'] + "_" + (event['start-time'] || 'allday');
|
||||
let extractedUrl = "";
|
||||
if (!event.url && event.description) {
|
||||
let urlMatch = event.description.match(/https?:\/\/[^\s]+/);
|
||||
if (urlMatch)
|
||||
extractedUrl = urlMatch[0];
|
||||
}
|
||||
let eventTemplate = {
|
||||
"id": eventId,
|
||||
"title": event.title || "Untitled Event",
|
||||
"start": startTime,
|
||||
"end": endTime,
|
||||
"location": event.location || "",
|
||||
"description": event.description || "",
|
||||
"url": event.url || extractedUrl,
|
||||
"calendar": "",
|
||||
"color": "",
|
||||
"allDay": event['all-day'] === "True",
|
||||
"isMultiDay": startDate.toDateString() !== endDate.toDateString()
|
||||
};
|
||||
let currentDate = new Date(startDate);
|
||||
while (currentDate <= endDate) {
|
||||
let dateKey = Qt.formatDate(currentDate, "yyyy-MM-dd");
|
||||
if (!newEventsByDate[dateKey])
|
||||
newEventsByDate[dateKey] = [];
|
||||
|
||||
let existingEvent = newEventsByDate[dateKey].find(e => e.id === eventId);
|
||||
if (existingEvent) {
|
||||
currentDate.setDate(currentDate.getDate() + 1);
|
||||
continue;
|
||||
}
|
||||
let dayEvent = Object.assign({}, eventTemplate);
|
||||
if (currentDate.getTime() === startDate.getTime()) {
|
||||
dayEvent.start = new Date(startTime);
|
||||
} else {
|
||||
dayEvent.start = new Date(currentDate);
|
||||
if (!dayEvent.allDay)
|
||||
dayEvent.start.setHours(0, 0, 0, 0);
|
||||
}
|
||||
if (currentDate.getTime() === endDate.getTime()) {
|
||||
dayEvent.end = new Date(endTime);
|
||||
} else {
|
||||
dayEvent.end = new Date(currentDate);
|
||||
if (!dayEvent.allDay)
|
||||
dayEvent.end.setHours(23, 59, 59, 999);
|
||||
}
|
||||
newEventsByDate[dateKey].push(dayEvent);
|
||||
currentDate.setDate(currentDate.getDate() + 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
root.eventsByDate = newEventsByDate;
|
||||
root.lastError = "";
|
||||
} catch (error) {
|
||||
root.lastError = "Failed to parse events JSON: " + error.toString();
|
||||
root.eventsByDate = {};
|
||||
}
|
||||
eventsProcess.rawOutput = "";
|
||||
}
|
||||
|
||||
stdout: SplitParser {
|
||||
splitMarker: "\n"
|
||||
onRead: data => {
|
||||
eventsProcess.rawOutput += data + "\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -11,87 +11,71 @@ Singleton {
|
||||
id: root
|
||||
readonly property var log: Log.scoped("CalendarService")
|
||||
|
||||
readonly property string backendPref: SettingsData.calendarBackend
|
||||
readonly property string activeBackend: {
|
||||
switch (backendPref) {
|
||||
case "khal":
|
||||
return "khal";
|
||||
case "dankcal":
|
||||
return "dankcal";
|
||||
default:
|
||||
if (dankBackend.connected)
|
||||
return "dankcal";
|
||||
if (khalBackend.installed)
|
||||
return "khal";
|
||||
return "none";
|
||||
}
|
||||
}
|
||||
|
||||
readonly property bool calendarAvailable: activeBackend !== "none"
|
||||
readonly property bool isDankActive: activeBackend === "dankcal"
|
||||
readonly property bool canCreateEvents: isDankActive && dankBackend.connected
|
||||
property bool khalAvailable: true // compatibility alias - calendar card UI gate
|
||||
|
||||
readonly property bool dankConnected: dankBackend.connected
|
||||
readonly property bool dankBinaryExists: dankBackend.binaryExists
|
||||
readonly property bool dankNeedsLaunch: backendPref === "dankcal" && !dankBackend.connected && !dankBackend.socketFound
|
||||
|
||||
property var calendars: dankBackend.calendars
|
||||
property bool khalAvailable: true // Always true to enable DMS calendar card UI
|
||||
property bool khalInstalled: false // Tracks if khal is actually on the system
|
||||
property var eventsByDate: ({})
|
||||
property var khalEventsByDate: ({})
|
||||
property var taskEventsByDate: ({})
|
||||
property var localTasks: ({})
|
||||
property bool isLoading: khalBackend.isLoading
|
||||
property bool isLoading: false
|
||||
property string lastError: ""
|
||||
|
||||
property bool _rangeSet: false
|
||||
property date lastStartDate
|
||||
property date lastEndDate
|
||||
property string khalDateFormat: "MM/dd/yyyy"
|
||||
|
||||
onKhalEventsByDateChanged: mergeEvents()
|
||||
onTaskEventsByDateChanged: mergeEvents()
|
||||
onActiveBackendChanged: {
|
||||
mergeEvents();
|
||||
if (_rangeSet)
|
||||
loadEvents(lastStartDate, lastEndDate);
|
||||
|
||||
function checkKhalAvailability() {
|
||||
if (!khalCheckProcess.running)
|
||||
khalCheckProcess.running = true;
|
||||
}
|
||||
|
||||
CalendarKhalBackend {
|
||||
id: khalBackend
|
||||
onEventsByDateChanged: root.mergeEvents()
|
||||
function detectKhalDateFormat() {
|
||||
if (!khalFormatProcess.running)
|
||||
khalFormatProcess.running = true;
|
||||
}
|
||||
|
||||
CalendarDankBackend {
|
||||
id: dankBackend
|
||||
enabled: root.backendPref === "dankcal" || root.backendPref === "auto"
|
||||
onEventsByDateChanged: root.mergeEvents()
|
||||
onConnectedChanged: {
|
||||
if (connected && root._rangeSet)
|
||||
root.loadEvents(root.lastStartDate, root.lastEndDate);
|
||||
}
|
||||
function parseKhalDateFormat(formatExample) {
|
||||
let qtFormat = formatExample.replace("12", "MM").replace("21", "dd").replace("2013", "yyyy");
|
||||
return {
|
||||
format: qtFormat,
|
||||
parser: null
|
||||
};
|
||||
}
|
||||
|
||||
function loadCurrentMonth() {
|
||||
if (!root.khalAvailable)
|
||||
return;
|
||||
let today = new Date();
|
||||
let firstDay = new Date(today.getFullYear(), today.getMonth(), 1);
|
||||
let lastDay = new Date(today.getFullYear(), today.getMonth() + 1, 0);
|
||||
// Add padding
|
||||
let startDate = new Date(firstDay);
|
||||
startDate.setDate(startDate.getDate() - firstDay.getDay() - 7);
|
||||
let endDate = new Date(lastDay);
|
||||
endDate.setDate(endDate.getDate() + (6 - lastDay.getDay()) + 7);
|
||||
loadEvents(startDate, endDate);
|
||||
}
|
||||
|
||||
function loadEvents(startDate, endDate) {
|
||||
if (!root.khalInstalled) {
|
||||
return;
|
||||
}
|
||||
if (eventsProcess.running) {
|
||||
return;
|
||||
}
|
||||
// Store last requested date range for refresh timer
|
||||
root.lastStartDate = startDate;
|
||||
root.lastEndDate = endDate;
|
||||
root._rangeSet = true;
|
||||
switch (activeBackend) {
|
||||
case "dankcal":
|
||||
dankBackend.loadEvents(startDate, endDate);
|
||||
break;
|
||||
case "khal":
|
||||
khalBackend.loadEvents(startDate, endDate);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function _activeBackendEventsByDate() {
|
||||
switch (activeBackend) {
|
||||
case "dankcal":
|
||||
return dankBackend.eventsByDate;
|
||||
case "khal":
|
||||
return khalBackend.eventsByDate;
|
||||
default:
|
||||
return {};
|
||||
}
|
||||
root.isLoading = true;
|
||||
// Format dates for khal using detected format
|
||||
let startDateStr = Qt.formatDate(startDate, root.khalDateFormat);
|
||||
let endDateStr = Qt.formatDate(endDate, root.khalDateFormat);
|
||||
eventsProcess.requestStartDate = startDate;
|
||||
eventsProcess.requestEndDate = endDate;
|
||||
eventsProcess.command = ["khal", "list", "--json", "title", "--json", "description", "--json", "start-date", "--json", "start-time", "--json", "end-date", "--json", "end-time", "--json", "all-day", "--json", "location", "--json", "url", startDateStr, endDateStr];
|
||||
eventsProcess.running = true;
|
||||
}
|
||||
|
||||
function getEventsForDate(date) {
|
||||
@@ -100,54 +84,11 @@ Singleton {
|
||||
}
|
||||
|
||||
function hasEventsForDate(date) {
|
||||
return getEventsForDate(date).length > 0;
|
||||
}
|
||||
|
||||
function writableCalendars() {
|
||||
return isDankActive ? dankBackend.writableCalendars() : [];
|
||||
}
|
||||
|
||||
function defaultCalendar() {
|
||||
return isDankActive ? dankBackend.defaultCalendar() : null;
|
||||
}
|
||||
|
||||
function launchDankCalendar() {
|
||||
dankBackend.launch();
|
||||
}
|
||||
|
||||
function createEvent(fields, callback) {
|
||||
if (isDankActive) {
|
||||
dankBackend.createEvent(fields, callback);
|
||||
return;
|
||||
}
|
||||
if (callback)
|
||||
callback({
|
||||
"error": "read-only backend"
|
||||
});
|
||||
}
|
||||
|
||||
function updateEvent(id, fields, callback) {
|
||||
if (isDankActive) {
|
||||
dankBackend.updateEvent(id, fields, callback);
|
||||
return;
|
||||
}
|
||||
if (callback)
|
||||
callback({
|
||||
"error": "read-only backend"
|
||||
});
|
||||
}
|
||||
|
||||
function deleteEvent(id, callback) {
|
||||
if (isDankActive) {
|
||||
dankBackend.deleteEvent(id, callback);
|
||||
return;
|
||||
}
|
||||
if (callback)
|
||||
callback({
|
||||
"error": "read-only backend"
|
||||
});
|
||||
let events = getEventsForDate(date);
|
||||
return events.length > 0;
|
||||
}
|
||||
|
||||
// In-memory Task CRUD methods
|
||||
function loadTasks(text) {
|
||||
if (!text || text.trim() === "") {
|
||||
root.localTasks = {};
|
||||
@@ -188,7 +129,8 @@ Singleton {
|
||||
"description": "Task from your Planner",
|
||||
"url": "",
|
||||
"calendar": "Todo Planner",
|
||||
"color": "#10B981",
|
||||
"color": "#10B981" // Pastel Green
|
||||
,
|
||||
"allDay": true,
|
||||
"isMultiDay": false
|
||||
});
|
||||
@@ -200,8 +142,9 @@ Singleton {
|
||||
function addTaskForDate(date, text) {
|
||||
let dateKey = Qt.formatDate(date, "yyyy-MM-dd");
|
||||
let tasks = Object.assign({}, root.localTasks);
|
||||
if (!tasks[dateKey])
|
||||
if (!tasks[dateKey]) {
|
||||
tasks[dateKey] = [];
|
||||
}
|
||||
let taskId = (new Date().getTime()) + "-dms";
|
||||
tasks[dateKey].push({
|
||||
"id": taskId,
|
||||
@@ -244,10 +187,11 @@ Singleton {
|
||||
let list = tasks[dateKey];
|
||||
let filtered = list.filter(item => item.id !== cleanId);
|
||||
if (filtered.length !== list.length) {
|
||||
if (filtered.length === 0)
|
||||
if (filtered.length === 0) {
|
||||
delete tasks[dateKey];
|
||||
else
|
||||
} else {
|
||||
tasks[dateKey] = filtered;
|
||||
}
|
||||
updated = true;
|
||||
break;
|
||||
}
|
||||
@@ -264,17 +208,20 @@ Singleton {
|
||||
let tasks = Object.assign({}, root.localTasks);
|
||||
let v = tasks[dateKey] || [];
|
||||
let idToItem = {};
|
||||
for (let item of v)
|
||||
for (let item of v) {
|
||||
idToItem[item.id] = item;
|
||||
}
|
||||
let newV = [];
|
||||
for (let tid of orderedIds) {
|
||||
if (idToItem[tid])
|
||||
if (idToItem[tid]) {
|
||||
newV.push(idToItem[tid]);
|
||||
}
|
||||
}
|
||||
let orderedSet = new Set(orderedIds);
|
||||
for (let item of v) {
|
||||
if (!orderedSet.has(item.id))
|
||||
if (!orderedSet.has(item.id)) {
|
||||
newV.push(item);
|
||||
}
|
||||
}
|
||||
tasks[dateKey] = newV;
|
||||
root.localTasks = tasks;
|
||||
@@ -307,24 +254,30 @@ Singleton {
|
||||
|
||||
function mergeEvents() {
|
||||
let merged = {};
|
||||
let backendEvents = _activeBackendEventsByDate();
|
||||
|
||||
for (let dateKey in backendEvents)
|
||||
merged[dateKey] = [].concat(backendEvents[dateKey]);
|
||||
// Merge khal events
|
||||
for (let dateKey in root.khalEventsByDate) {
|
||||
merged[dateKey] = [].concat(root.khalEventsByDate[dateKey]);
|
||||
}
|
||||
|
||||
// Merge task events
|
||||
for (let dateKey in root.taskEventsByDate) {
|
||||
if (!merged[dateKey])
|
||||
if (!merged[dateKey]) {
|
||||
merged[dateKey] = [];
|
||||
}
|
||||
for (let event of root.taskEventsByDate[dateKey]) {
|
||||
if (!merged[dateKey].some(e => e.id === event.id))
|
||||
if (!merged[dateKey].some(e => e.id === event.id)) {
|
||||
merged[dateKey].push(event);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Sort events within each date
|
||||
for (let dateKey in merged) {
|
||||
let list = merged[dateKey];
|
||||
for (let idx = 0; idx < list.length; idx++)
|
||||
for (let idx = 0; idx < list.length; idx++) {
|
||||
list[idx]._origIdx = idx;
|
||||
}
|
||||
list.sort((a, b) => {
|
||||
let diff = a.start.getTime() - b.start.getTime();
|
||||
if (diff !== 0)
|
||||
@@ -336,6 +289,12 @@ Singleton {
|
||||
root.eventsByDate = merged;
|
||||
}
|
||||
|
||||
// Initialize on component completion
|
||||
Component.onCompleted: {
|
||||
detectKhalDateFormat();
|
||||
}
|
||||
|
||||
// Atomic file view for tasks
|
||||
FileView {
|
||||
id: tasksFileView
|
||||
path: Quickshell.env("HOME") + "/.config/niri-calendar-todo/tasks.json"
|
||||
@@ -345,11 +304,233 @@ Singleton {
|
||||
watchChanges: true
|
||||
printErrors: false
|
||||
|
||||
onLoaded: loadTasks(tasksFileView.text())
|
||||
onLoaded: {
|
||||
loadTasks(tasksFileView.text());
|
||||
}
|
||||
|
||||
onLoadFailed: {
|
||||
root.localTasks = {};
|
||||
root.taskEventsByDate = {};
|
||||
}
|
||||
}
|
||||
|
||||
// Process for detecting khal date format
|
||||
Process {
|
||||
id: khalFormatProcess
|
||||
|
||||
command: ["khal", "printformats"]
|
||||
running: false
|
||||
onExited: exitCode => {
|
||||
if (exitCode !== 0) {
|
||||
checkKhalAvailability();
|
||||
}
|
||||
}
|
||||
|
||||
stdout: StdioCollector {
|
||||
onStreamFinished: {
|
||||
let lines = text.split('\n');
|
||||
for (let line of lines) {
|
||||
if (line.startsWith('dateformat:')) {
|
||||
let formatExample = line.substring(line.indexOf(':') + 1).trim();
|
||||
let formatInfo = parseKhalDateFormat(formatExample);
|
||||
root.khalDateFormat = formatInfo.format;
|
||||
break;
|
||||
}
|
||||
}
|
||||
checkKhalAvailability();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Process for checking khal configuration
|
||||
Process {
|
||||
id: khalCheckProcess
|
||||
|
||||
command: ["khal", "list", "today"]
|
||||
running: false
|
||||
onExited: exitCode => {
|
||||
root.khalInstalled = (exitCode === 0);
|
||||
if (root.khalInstalled) {
|
||||
loadCurrentMonth();
|
||||
} else {
|
||||
loadEvents(root.lastStartDate || new Date(), root.lastEndDate || new Date());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Process for loading events
|
||||
Process {
|
||||
id: eventsProcess
|
||||
|
||||
property date requestStartDate
|
||||
property date requestEndDate
|
||||
property string rawOutput: ""
|
||||
|
||||
running: false
|
||||
onExited: exitCode => {
|
||||
root.isLoading = false;
|
||||
if (exitCode !== 0) {
|
||||
root.lastError = "Failed to load events (exit code: " + exitCode + ")";
|
||||
return;
|
||||
}
|
||||
try {
|
||||
let newEventsByDate = {};
|
||||
let lines = eventsProcess.rawOutput.split('\n');
|
||||
for (let line of lines) {
|
||||
line = line.trim();
|
||||
if (!line || line === "[]")
|
||||
continue;
|
||||
|
||||
// Parse JSON line
|
||||
let dayEvents = JSON.parse(line);
|
||||
// Process each event in this day's array
|
||||
for (let event of dayEvents) {
|
||||
if (!event.title)
|
||||
continue;
|
||||
|
||||
// Parse start and end dates using detected format
|
||||
let startDate, endDate;
|
||||
if (event['start-date']) {
|
||||
startDate = Date.fromLocaleString(I18n.locale(), event['start-date'], root.khalDateFormat);
|
||||
} else {
|
||||
startDate = new Date();
|
||||
}
|
||||
if (event['end-date']) {
|
||||
endDate = Date.fromLocaleString(I18n.locale(), event['end-date'], root.khalDateFormat);
|
||||
} else {
|
||||
endDate = new Date(startDate);
|
||||
}
|
||||
// Create start/end times
|
||||
let startTime = new Date(startDate);
|
||||
let endTime = new Date(endDate);
|
||||
if (event['start-time'] && event['all-day'] !== "True") {
|
||||
// Parse time if available and not all-day
|
||||
let timeStr = event['start-time'];
|
||||
if (timeStr) {
|
||||
// Match time with optional seconds and AM/PM
|
||||
let timeParts = timeStr.match(/(\d+):(\d+)(?::\d+)?\s*(AM|PM)?/i);
|
||||
if (timeParts) {
|
||||
let hours = parseInt(timeParts[1]);
|
||||
let minutes = parseInt(timeParts[2]);
|
||||
|
||||
// Handle AM/PM conversion if present
|
||||
if (timeParts[3]) {
|
||||
let period = timeParts[3].toUpperCase();
|
||||
if (period === 'PM' && hours !== 12) {
|
||||
hours += 12;
|
||||
} else if (period === 'AM' && hours === 12) {
|
||||
hours = 0;
|
||||
}
|
||||
}
|
||||
|
||||
startTime.setHours(hours, minutes);
|
||||
if (event['end-time']) {
|
||||
let endTimeParts = event['end-time'].match(/(\d+):(\d+)(?::\d+)?\s*(AM|PM)?/i);
|
||||
if (endTimeParts) {
|
||||
let endHours = parseInt(endTimeParts[1]);
|
||||
let endMinutes = parseInt(endTimeParts[2]);
|
||||
|
||||
// Handle AM/PM conversion if present
|
||||
if (endTimeParts[3]) {
|
||||
let endPeriod = endTimeParts[3].toUpperCase();
|
||||
if (endPeriod === 'PM' && endHours !== 12) {
|
||||
endHours += 12;
|
||||
} else if (endPeriod === 'AM' && endHours === 12) {
|
||||
endHours = 0;
|
||||
}
|
||||
}
|
||||
|
||||
endTime.setHours(endHours, endMinutes);
|
||||
}
|
||||
} else {
|
||||
// Default to 1 hour duration on same day
|
||||
endTime = new Date(startTime);
|
||||
endTime.setHours(startTime.getHours() + 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
// Create unique ID for this event (to track multi-day events)
|
||||
let eventId = event.title + "_" + event['start-date'] + "_" + (event['start-time'] || 'allday');
|
||||
// Create event object template
|
||||
let extractedUrl = "";
|
||||
if (!event.url && event.description) {
|
||||
let urlMatch = event.description.match(/https?:\/\/[^\s]+/);
|
||||
if (urlMatch) {
|
||||
extractedUrl = urlMatch[0];
|
||||
}
|
||||
}
|
||||
let eventTemplate = {
|
||||
"id": eventId,
|
||||
"title": event.title || "Untitled Event",
|
||||
"start": startTime,
|
||||
"end": endTime,
|
||||
"location": event.location || "",
|
||||
"description": event.description || "",
|
||||
"url": event.url || extractedUrl,
|
||||
"calendar": "",
|
||||
"color": "",
|
||||
"allDay": event['all-day'] === "True",
|
||||
"isMultiDay": startDate.toDateString() !== endDate.toDateString()
|
||||
};
|
||||
// Add event to each day it spans
|
||||
let currentDate = new Date(startDate);
|
||||
while (currentDate <= endDate) {
|
||||
let dateKey = Qt.formatDate(currentDate, "yyyy-MM-dd");
|
||||
if (!newEventsByDate[dateKey])
|
||||
newEventsByDate[dateKey] = [];
|
||||
|
||||
// Check if this exact event is already added to this date (prevent duplicates)
|
||||
let existingEvent = newEventsByDate[dateKey].find(e => {
|
||||
return e.id === eventId;
|
||||
});
|
||||
if (existingEvent) {
|
||||
// Move to next day without adding duplicate
|
||||
currentDate.setDate(currentDate.getDate() + 1);
|
||||
continue;
|
||||
}
|
||||
// Create a copy of the event for this date
|
||||
let dayEvent = Object.assign({}, eventTemplate);
|
||||
// For multi-day events, adjust the display time for this specific day
|
||||
if (currentDate.getTime() === startDate.getTime()) {
|
||||
// First day - use original start time
|
||||
dayEvent.start = new Date(startTime);
|
||||
} else {
|
||||
// Subsequent days - start at beginning of day for all-day events
|
||||
dayEvent.start = new Date(currentDate);
|
||||
if (!dayEvent.allDay)
|
||||
dayEvent.start.setHours(0, 0, 0, 0);
|
||||
}
|
||||
if (currentDate.getTime() === endDate.getTime()) {
|
||||
// Last day - use original end time
|
||||
dayEvent.end = new Date(endTime);
|
||||
} else {
|
||||
// Earlier days - end at end of day for all-day events
|
||||
dayEvent.end = new Date(currentDate);
|
||||
if (!dayEvent.allDay)
|
||||
dayEvent.end.setHours(23, 59, 59, 999);
|
||||
}
|
||||
newEventsByDate[dateKey].push(dayEvent);
|
||||
// Move to next day
|
||||
currentDate.setDate(currentDate.getDate() + 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
root.khalEventsByDate = newEventsByDate;
|
||||
root.lastError = "";
|
||||
} catch (error) {
|
||||
root.lastError = "Failed to parse events JSON: " + error.toString();
|
||||
root.khalEventsByDate = {};
|
||||
}
|
||||
// Reset for next run
|
||||
eventsProcess.rawOutput = "";
|
||||
}
|
||||
|
||||
stdout: SplitParser {
|
||||
splitMarker: "\n"
|
||||
onRead: data => {
|
||||
eventsProcess.rawOutput += data + "\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -23,49 +23,6 @@ Singleton {
|
||||
property var tabsBeingCreated: ({})
|
||||
property bool metadataLoaded: false
|
||||
|
||||
// Shared live edit state across slideout and popout surfaces.
|
||||
property var sessionBuffers: ({})
|
||||
property int sessionBufferRevision: 0
|
||||
|
||||
function setSessionBuffer(tabId, content, baseline) {
|
||||
if (tabId === undefined || tabId === null || tabId < 0)
|
||||
return
|
||||
var next = Object.assign({}, sessionBuffers)
|
||||
if (content !== baseline) {
|
||||
next[tabId] = { content: content, baseline: baseline }
|
||||
} else {
|
||||
delete next[tabId]
|
||||
}
|
||||
sessionBuffers = next
|
||||
sessionBufferRevision++
|
||||
}
|
||||
|
||||
function getSessionBuffer(tabId) {
|
||||
return sessionBuffers[tabId]
|
||||
}
|
||||
|
||||
function clearSessionBuffer(tabId) {
|
||||
if (sessionBuffers[tabId] === undefined)
|
||||
return
|
||||
var next = Object.assign({}, sessionBuffers)
|
||||
delete next[tabId]
|
||||
sessionBuffers = next
|
||||
sessionBufferRevision++
|
||||
}
|
||||
|
||||
property var conflictTabId: -1
|
||||
property string conflictDiskContent: ""
|
||||
|
||||
function flagConflict(tabId, diskContent) {
|
||||
conflictDiskContent = diskContent
|
||||
conflictTabId = tabId
|
||||
}
|
||||
|
||||
function clearConflict() {
|
||||
conflictTabId = -1
|
||||
conflictDiskContent = ""
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
ensureDirectories()
|
||||
}
|
||||
@@ -252,10 +209,6 @@ Singleton {
|
||||
if (tabIndex < 0 || tabIndex >= tabs.length) return
|
||||
|
||||
var newTabs = tabs.slice()
|
||||
var closedTabId = newTabs[tabIndex] ? newTabs[tabIndex].id : -1
|
||||
clearSessionBuffer(closedTabId)
|
||||
if (conflictTabId === closedTabId)
|
||||
clearConflict()
|
||||
|
||||
if (newTabs.length <= 1) {
|
||||
var id = Date.now()
|
||||
|
||||
@@ -392,7 +392,8 @@ Singleton {
|
||||
function toggleSettingsWithTab(tabName: string) {
|
||||
if (settingsModal) {
|
||||
var idx = settingsModal.resolveTabIndex(tabName);
|
||||
settingsModal.setTabIndex(idx);
|
||||
if (idx >= 0)
|
||||
settingsModal.currentTabIndex = idx;
|
||||
settingsModal.toggle();
|
||||
return;
|
||||
}
|
||||
@@ -432,7 +433,8 @@ Singleton {
|
||||
return;
|
||||
}
|
||||
var idx = settingsModal.resolveTabIndex(tabName);
|
||||
settingsModal.setTabIndex(idx);
|
||||
if (idx >= 0)
|
||||
settingsModal.currentTabIndex = idx;
|
||||
toplevel.activate();
|
||||
return;
|
||||
}
|
||||
@@ -464,11 +466,12 @@ Singleton {
|
||||
if (_settingsWantsToggle) {
|
||||
_settingsWantsToggle = false;
|
||||
if (_settingsPendingTabIndex >= 0) {
|
||||
settingsModal?.setTabIndex(_settingsPendingTabIndex);
|
||||
settingsModal.currentTabIndex = _settingsPendingTabIndex;
|
||||
_settingsPendingTabIndex = -1;
|
||||
} else if (_settingsPendingTab) {
|
||||
var idx = settingsModal?.resolveTabIndex(_settingsPendingTab) ?? -1;
|
||||
settingsModal?.setTabIndex(idx);
|
||||
if (idx >= 0)
|
||||
settingsModal.currentTabIndex = idx;
|
||||
_settingsPendingTab = "";
|
||||
}
|
||||
settingsModal?.toggle();
|
||||
@@ -786,97 +789,21 @@ Singleton {
|
||||
networkInfoModal?.close();
|
||||
}
|
||||
|
||||
function closeNotepadSlideouts() {
|
||||
for (var i = 0; i < notepadSlideouts.length; i++) {
|
||||
if (notepadSlideouts[i] && notepadSlideouts[i].isVisible)
|
||||
notepadSlideouts[i].hide();
|
||||
}
|
||||
}
|
||||
|
||||
function openNotepadSlideout() {
|
||||
notepadPopout?.hide();
|
||||
function openNotepad() {
|
||||
if (notepadSlideouts.length > 0) {
|
||||
notepadSlideouts[0]?.show();
|
||||
}
|
||||
}
|
||||
|
||||
// Keep the notepad in a single presentation for default modes
|
||||
Connections {
|
||||
target: SettingsData
|
||||
function onNotepadDefaultModeChanged() {
|
||||
if (SettingsData.notepadDefaultMode === "popout") {
|
||||
var hadSlideout = false;
|
||||
for (var i = 0; i < root.notepadSlideouts.length; i++) {
|
||||
if (root.notepadSlideouts[i] && root.notepadSlideouts[i].isVisible) {
|
||||
hadSlideout = true;
|
||||
root.notepadSlideouts[i].hide();
|
||||
}
|
||||
}
|
||||
if (hadSlideout)
|
||||
root.openNotepadPopout();
|
||||
} else if (root.notepadPopout && root.notepadPopout.visible) {
|
||||
root.notepadPopout.hide();
|
||||
root.openNotepadSlideout();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function openNotepad() {
|
||||
if (SettingsData.notepadDefaultMode === "popout") {
|
||||
openNotepadPopout();
|
||||
return;
|
||||
}
|
||||
openNotepadSlideout();
|
||||
}
|
||||
|
||||
function closeNotepad() {
|
||||
if (SettingsData.notepadDefaultMode === "popout") {
|
||||
notepadPopout?.hide();
|
||||
return;
|
||||
}
|
||||
if (notepadSlideouts.length > 0) {
|
||||
notepadSlideouts[0]?.hide();
|
||||
}
|
||||
}
|
||||
|
||||
function toggleNotepad() {
|
||||
if (SettingsData.notepadDefaultMode === "popout") {
|
||||
toggleNotepadPopout();
|
||||
return;
|
||||
}
|
||||
if (notepadSlideouts.length > 0) {
|
||||
notepadSlideouts[0]?.toggle();
|
||||
}
|
||||
}
|
||||
|
||||
property var notepadPopout: null
|
||||
property var notepadPopoutLoader: null
|
||||
property bool _notepadPopoutWantsOpen: false
|
||||
|
||||
function openNotepadPopout() {
|
||||
closeNotepadSlideouts();
|
||||
if (notepadPopout) {
|
||||
notepadPopout.show();
|
||||
} else if (notepadPopoutLoader) {
|
||||
_notepadPopoutWantsOpen = true;
|
||||
notepadPopoutLoader.active = true;
|
||||
}
|
||||
}
|
||||
|
||||
function _onNotepadPopoutLoaded() {
|
||||
if (_notepadPopoutWantsOpen && notepadPopout) {
|
||||
_notepadPopoutWantsOpen = false;
|
||||
notepadPopout.show();
|
||||
}
|
||||
}
|
||||
|
||||
function toggleNotepadPopout() {
|
||||
if (notepadPopout) {
|
||||
if (!notepadPopout.visible)
|
||||
closeNotepadSlideouts();
|
||||
notepadPopout.toggle();
|
||||
} else {
|
||||
openNotepadPopout();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -13,12 +13,11 @@ Row {
|
||||
property var initialSelection: []
|
||||
property var currentSelection: initialSelection
|
||||
property bool checkEnabled: true
|
||||
property string size: "medium"
|
||||
property int buttonHeight: size === "small" ? 32 : 40
|
||||
property int minButtonWidth: size === "small" ? 56 : 64
|
||||
property int buttonPadding: size === "small" ? Theme.spacingM : Theme.spacingL
|
||||
property int checkIconSize: size === "small" ? Theme.iconSizeSmall - 2 : Theme.iconSizeSmall
|
||||
property int textSize: size === "small" ? Theme.fontSizeSmall : Theme.fontSizeMedium
|
||||
property int buttonHeight: 40
|
||||
property int minButtonWidth: 64
|
||||
property int buttonPadding: Theme.spacingL
|
||||
property int checkIconSize: Theme.iconSizeSmall
|
||||
property int textSize: Theme.fontSizeMedium
|
||||
property bool userInteracted: false
|
||||
|
||||
signal selectionChanged(int index, bool selected)
|
||||
|
||||
@@ -16,28 +16,21 @@ PanelWindow {
|
||||
property var targetScreen: null
|
||||
property var modelData: null
|
||||
property bool triggerUsesOverlayLayer: false
|
||||
// Drop off the Overlay layer (back to Top) while an overlay modal
|
||||
property bool suppressOverlayLayer: false
|
||||
property real slideoutWidth: 480
|
||||
property bool expandable: false
|
||||
property bool expandedWidth: false
|
||||
property real expandedWidthValue: 960
|
||||
property real edgeGap: 0
|
||||
property string slideEdge: "right"
|
||||
readonly property bool slideFromLeft: slideEdge === "left"
|
||||
property Component content: null
|
||||
property string title: ""
|
||||
property alias container: contentContainer
|
||||
property real customTransparency: -1
|
||||
property bool mappedVisible: false
|
||||
signal aboutToHide
|
||||
signal revealed
|
||||
|
||||
function show() {
|
||||
mappedVisible = true;
|
||||
Qt.callLater(() => {
|
||||
isVisible = true;
|
||||
revealed();
|
||||
});
|
||||
}
|
||||
|
||||
@@ -59,9 +52,9 @@ PanelWindow {
|
||||
|
||||
anchors.top: true
|
||||
anchors.bottom: true
|
||||
anchors.right: !root.slideFromLeft
|
||||
anchors.left: root.slideFromLeft
|
||||
anchors.right: true
|
||||
|
||||
// Expandable: fixed max surface width; strip width is slideContainer only (keeps blur/mask aligned).
|
||||
implicitWidth: expandable ? expandedWidthValue : slideoutWidth
|
||||
implicitHeight: modelData ? modelData.height : 800
|
||||
|
||||
@@ -69,22 +62,21 @@ PanelWindow {
|
||||
|
||||
readonly property bool slideoutBlurActive: root.visible && BlurService.enabled && Theme.connectedSurfaceBlurEnabled
|
||||
|
||||
WlrLayershell.layer: (!suppressOverlayLayer && (triggerUsesOverlayLayer || CompositorService.framePeerSurfacesUseOverlayForScreen(modelData))) ? WlrLayershell.Overlay : WlrLayershell.Top
|
||||
WlrLayershell.layer: (triggerUsesOverlayLayer || CompositorService.framePeerSurfacesUseOverlayForScreen(modelData)) ? WlrLayershell.Overlay : WlrLayershell.Top
|
||||
WlrLayershell.exclusiveZone: 0
|
||||
WlrLayershell.keyboardFocus: isVisible ? WlrKeyboardFocus.OnDemand : WlrKeyboardFocus.None
|
||||
|
||||
readonly property real dpr: CompositorService.getScreenScale(root.screen)
|
||||
readonly property real alignedWidth: Theme.px(expandable && expandedWidth ? expandedWidthValue : slideoutWidth, dpr)
|
||||
readonly property real alignedHeight: Theme.px(modelData ? modelData.height : 800, dpr)
|
||||
readonly property real alignedEdgeGap: Theme.px(edgeGap, dpr)
|
||||
readonly property real slideoutSlideSnapX: Theme.snap(slideContainer.slideOffset, dpr)
|
||||
|
||||
mask: Region {
|
||||
item: Rectangle {
|
||||
x: root.slideFromLeft ? root.alignedEdgeGap : (root.width - slideContainer.width - root.alignedEdgeGap)
|
||||
y: root.alignedEdgeGap
|
||||
x: root.width - slideContainer.width
|
||||
y: 0
|
||||
width: slideContainer.width
|
||||
height: root.height - root.alignedEdgeGap * 2
|
||||
height: root.height
|
||||
}
|
||||
}
|
||||
|
||||
@@ -92,21 +84,16 @@ PanelWindow {
|
||||
id: slideContainer
|
||||
anchors.top: parent.top
|
||||
anchors.bottom: parent.bottom
|
||||
anchors.right: root.slideFromLeft ? undefined : parent.right
|
||||
anchors.left: root.slideFromLeft ? parent.left : undefined
|
||||
anchors.topMargin: root.alignedEdgeGap
|
||||
anchors.bottomMargin: root.alignedEdgeGap
|
||||
anchors.rightMargin: root.alignedEdgeGap
|
||||
anchors.leftMargin: root.alignedEdgeGap
|
||||
anchors.right: parent.right
|
||||
width: root.alignedWidth
|
||||
height: root.alignedHeight - root.alignedEdgeGap * 2
|
||||
height: root.alignedHeight
|
||||
|
||||
property real slideOffset: root.slideFromLeft ? -root.alignedWidth : root.alignedWidth
|
||||
property real slideOffset: root.alignedWidth
|
||||
|
||||
Connections {
|
||||
target: root
|
||||
function onIsVisibleChanged() {
|
||||
slideContainer.slideOffset = root.isVisible ? 0 : (root.slideFromLeft ? -slideContainer.width : slideContainer.width);
|
||||
slideContainer.slideOffset = root.isVisible ? 0 : slideContainer.width;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -124,6 +111,7 @@ PanelWindow {
|
||||
}
|
||||
}
|
||||
|
||||
// Expandable only; mask/blur bind to slideContainer geometry so they track this animation.
|
||||
Behavior on width {
|
||||
enabled: root.expandable
|
||||
NumberAnimation {
|
||||
@@ -229,6 +217,7 @@ PanelWindow {
|
||||
}
|
||||
}
|
||||
|
||||
// Blur region from slideContainer (not layered contentRect); position uses x + slideoutSlideSnapX, not mapToItem(root).
|
||||
WindowBlur {
|
||||
targetWindow: root
|
||||
blurX: root.slideoutBlurActive ? slideContainer.x + root.slideoutSlideSnapX : 0
|
||||
|
||||
@@ -23,7 +23,6 @@ StyledRect {
|
||||
|
||||
property alias text: textInput.text
|
||||
property string placeholderText: ""
|
||||
property string labelText: ""
|
||||
property alias font: textInput.font
|
||||
property alias textColor: textInput.color
|
||||
property alias echoMode: textInput.echoMode
|
||||
@@ -86,10 +85,8 @@ StyledRect {
|
||||
textInput.insert(textInput.cursorPosition, str);
|
||||
}
|
||||
|
||||
readonly property real labelBandHeight: Math.round(Theme.fontSizeSmall * 1.4) + Theme.spacingXS * 2
|
||||
|
||||
width: 200
|
||||
height: labelText !== "" ? Math.round(Theme.fontSizeMedium * 3) + labelBandHeight : Math.round(Theme.fontSizeMedium * 3)
|
||||
height: Math.round(Theme.fontSizeMedium * 3)
|
||||
radius: cornerRadius
|
||||
color: backgroundColor
|
||||
border.color: textInput.activeFocus ? focusedBorderColor : normalBorderColor
|
||||
@@ -100,27 +97,13 @@ StyledRect {
|
||||
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: Theme.spacingM
|
||||
anchors.verticalCenter: textInput.verticalCenter
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
name: leftIconName
|
||||
size: leftIconSize
|
||||
color: textInput.activeFocus ? leftIconFocusedColor : leftIconColor
|
||||
visible: leftIconName !== ""
|
||||
}
|
||||
|
||||
StyledText {
|
||||
id: fieldLabel
|
||||
|
||||
anchors.left: textInput.left
|
||||
anchors.right: textInput.right
|
||||
anchors.top: parent.top
|
||||
anchors.topMargin: Theme.spacingXS
|
||||
text: root.labelText
|
||||
visible: root.labelText !== ""
|
||||
font.pixelSize: Theme.fontSizeSmall
|
||||
color: textInput.activeFocus ? Theme.primary : Theme.surfaceVariantText
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
|
||||
TextInput {
|
||||
id: textInput
|
||||
|
||||
@@ -129,7 +112,7 @@ StyledRect {
|
||||
anchors.right: rightButtonsRow.left
|
||||
anchors.rightMargin: rightButtonsRow.visible ? Theme.spacingS : Theme.spacingM
|
||||
anchors.top: parent.top
|
||||
anchors.topMargin: root.labelText !== "" ? root.labelBandHeight : root.topPadding
|
||||
anchors.topMargin: root.topPadding
|
||||
anchors.bottom: parent.bottom
|
||||
anchors.bottomMargin: root.bottomPadding
|
||||
font.pixelSize: Theme.fontSizeMedium
|
||||
|
||||
@@ -148,7 +148,7 @@ Rectangle {
|
||||
iconColor: Theme.surfaceVariantText
|
||||
onClicked: {
|
||||
PopoutService.closeControlCenter();
|
||||
PopoutService.openSettingsWithTab("network_vpn");
|
||||
PopoutService.openSettingsWithTab("network");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -29,8 +29,7 @@ LANGUAGES = {
|
||||
"nl": "nl.json",
|
||||
"ru": "ru.json",
|
||||
"de": "de.json",
|
||||
"sv": "sv.json",
|
||||
"vi": "vi.json"
|
||||
"sv": "sv.json"
|
||||
}
|
||||
|
||||
def error(msg):
|
||||
|
||||
+733
-1069
File diff suppressed because it is too large
Load Diff
@@ -102,10 +102,7 @@ TAB_INDEX_MAP = {
|
||||
"DockTab.qml": 5,
|
||||
"DankBarAppearanceTab.qml": 6,
|
||||
"WorkspaceAppearanceCard.qml": 6,
|
||||
"NetworkStatusTab.qml": 7,
|
||||
"NetworkEthernetTab.qml": 39,
|
||||
"NetworkWifiTab.qml": 40,
|
||||
"NetworkVpnTab.qml": 41,
|
||||
"NetworkTab.qml": 7,
|
||||
"PrinterTab.qml": 8,
|
||||
"LauncherTab.qml": 9,
|
||||
"ThemeColorsTab.qml": 10,
|
||||
@@ -175,9 +172,6 @@ TAB_CATEGORY_MAP = {
|
||||
36: "Autostart",
|
||||
37: "Personalization",
|
||||
38: "Applications",
|
||||
39: "Network",
|
||||
40: "Network",
|
||||
41: "Network",
|
||||
}
|
||||
|
||||
SEARCHABLE_COMPONENTS = [
|
||||
@@ -452,14 +446,8 @@ def parse_tabs_from_sidebar(sidebar_file):
|
||||
return tabs
|
||||
|
||||
|
||||
def generate_tab_entries(sidebar_file, settings_entries=None):
|
||||
def generate_tab_entries(sidebar_file):
|
||||
tabs = parse_tabs_from_sidebar(sidebar_file)
|
||||
settings_entries = settings_entries or []
|
||||
highlightable_labels = {
|
||||
(entry["tabIndex"], entry["label"])
|
||||
for entry in settings_entries
|
||||
if not str(entry["section"]).startswith("_tab_")
|
||||
}
|
||||
|
||||
label_counts = Counter([t["label"] for t in tabs])
|
||||
|
||||
@@ -472,9 +460,6 @@ def generate_tab_entries(sidebar_file, settings_entries=None):
|
||||
)
|
||||
category = TAB_CATEGORY_MAP.get(tab["tabIndex"], "Settings")
|
||||
|
||||
if (tab["tabIndex"], label) in highlightable_labels:
|
||||
continue
|
||||
|
||||
keywords = enrich_keywords(tab["label"], None, category, [])
|
||||
|
||||
if tab["parent"]:
|
||||
@@ -552,7 +537,7 @@ def main():
|
||||
|
||||
print("Extracting settings search index...")
|
||||
settings_entries = extract_settings_index(root_dir)
|
||||
tab_entries = generate_tab_entries(sidebar_file, settings_entries)
|
||||
tab_entries = generate_tab_entries(sidebar_file)
|
||||
|
||||
all_entries = tab_entries + settings_entries
|
||||
|
||||
@@ -561,7 +546,6 @@ def main():
|
||||
output_path = script_dir / "settings_search_index.json"
|
||||
with open(output_path, "w", encoding="utf-8") as f:
|
||||
json.dump(all_entries, f, indent=2, ensure_ascii=False)
|
||||
f.write("\n")
|
||||
|
||||
print(f"Found {len(settings_entries)} searchable settings")
|
||||
print(f"Found {len(tab_entries)} tab entries")
|
||||
|
||||
@@ -81,7 +81,7 @@
|
||||
"%1 online": "%1 online"
|
||||
},
|
||||
"%1 tasks": {
|
||||
"%1 tasks": "%1 Aufgaben"
|
||||
"%1 tasks": ""
|
||||
},
|
||||
"%1 update": {
|
||||
"%1 update": "%1 Update"
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 Tag"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 Gerät verbunden"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 Stunde 30 Minuten"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 Minute"
|
||||
},
|
||||
@@ -159,10 +153,7 @@
|
||||
"1 second": "1 Sekunde"
|
||||
},
|
||||
"1 task": {
|
||||
"1 task": "1 Aufgabe"
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
"1 task": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 Minuten"
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 Min."
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 Minuten"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 Min."
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 Minuten"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 Sekunden"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 Minuten"
|
||||
},
|
||||
@@ -459,7 +441,7 @@
|
||||
"Add a custom prefix to all application launches. This can be used for things like 'uwsm-app', 'systemd-run', or other command wrappers.": "Fügen Sie allen Anwendungsstarts ein benutzerdefiniertes Präfix hinzu. Dies kann für Dinge wie 'uwsm-app', 'systemd-run' oder andere Befehls-Wrapper verwendet werden."
|
||||
},
|
||||
"Add a task...": {
|
||||
"Add a task...": "Aufgabe hinzufügen..."
|
||||
"Add a task...": ""
|
||||
},
|
||||
"Add and configure widgets that appear on your desktop": {
|
||||
"Add and configure widgets that appear on your desktop": "Widgets hinzufügen und konfigurieren, die auf Ihrem Desktop erscheinen"
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Über Adresse hinzufügen"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": "Übereinstimmung hinzufügen"
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "Den neuen Benutzer zur Gruppe „%1“ hinzufügen, damit er „dms greeter sync --profile“ ausführen kann."
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "Zulassen"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Klicks durch das Widget zulassen"
|
||||
},
|
||||
@@ -540,7 +513,7 @@
|
||||
"Already on that session": "Bereits in dieser Sitzung"
|
||||
},
|
||||
"Also group repeated application icons on the active workspace": {
|
||||
"Also group repeated application icons on the active workspace": "Wiederholte Anwendungssymbole auch auf dem aktiven Arbeitsbereich gruppieren"
|
||||
"Also group repeated application icons on the active workspace": ""
|
||||
},
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": {
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": "Alt+←/Zurück: Zurück • F1/I: Datei Info • F10: Hilfe • Esc: Schließen"
|
||||
@@ -585,7 +558,7 @@
|
||||
"Analyzing configuration...": "Konfiguration wird analysiert..."
|
||||
},
|
||||
"Anchor": {
|
||||
"Anchor": "Anker"
|
||||
"Anchor": ""
|
||||
},
|
||||
"Animation Duration": {
|
||||
"Animation Duration": "Animationsdauer"
|
||||
@@ -612,7 +585,7 @@
|
||||
"App ID": "App-ID"
|
||||
},
|
||||
"App ID (e.g. firefox)": {
|
||||
"App ID (e.g. firefox)": "App-ID (z. B. firefox)"
|
||||
"App ID (e.g. firefox)": ""
|
||||
},
|
||||
"App ID Substitutions": {
|
||||
"App ID Substitutions": "App-ID-Ersetzungen"
|
||||
@@ -669,10 +642,10 @@
|
||||
"Apply warm color temperature to reduce eye strain. Use automation settings below to control when it activates.": "Warmes Farbschema für weniger Augenbelastung. Automatisierungseinstellungen unten zur Aktivierung."
|
||||
},
|
||||
"Applying authentication changes...": {
|
||||
"Applying authentication changes...": "Authentifizierungsänderungen werden angewendet..."
|
||||
"Applying authentication changes...": ""
|
||||
},
|
||||
"Applying auto-login on startup...": {
|
||||
"Applying auto-login on startup...": "Automatische Anmeldung beim Start wird angewendet..."
|
||||
"Applying auto-login on startup...": ""
|
||||
},
|
||||
"Apps": {
|
||||
"Apps": "Apps"
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "Mindestens ein Ausgang muss aktiviert bleiben"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "Verbinden"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Auto (Breit)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Automatischer Standort"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Automatische Popup-Abstände"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "Automatischer Modus ist aktiviert. Die manuelle Profilauswahl ist deaktiviert."
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Automatisch löschen nach"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": "Automatische Anmeldung beim Start"
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Auto-Speichern..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Bilschirmsperrung aktivieren wenn das System in den Ruhemodus wechselt"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Automatisierung"
|
||||
},
|
||||
@@ -987,17 +942,14 @@
|
||||
"Balanced palette with focused accents (default).": "Ausgewählte Farbpalette mit Akzenten (Standard)."
|
||||
},
|
||||
"Bar": {
|
||||
"Bar": "Leiste"
|
||||
"Bar": ""
|
||||
},
|
||||
"Bar %1": {
|
||||
"Bar %1": "Leiste %1"
|
||||
"Bar %1": ""
|
||||
},
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Leistenkonfiguration"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Leistenschatten"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "Den Hintergrund hinter Leisten, Pop-outs, Modalen und Benachrichtigungen weichzeichnen. Erfordert Compositor-Unterstützung und Konfiguration."
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Hintergrundbild weichzeichnen, wenn Niri-Übersicht geöffnet ist"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Textkörper"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "Fett"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "Kalender"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Kamera"
|
||||
},
|
||||
@@ -1338,7 +1281,7 @@
|
||||
"Checking for updates...": "Suche nach Updates..."
|
||||
},
|
||||
"Checking whether sudo authentication is needed...": {
|
||||
"Checking whether sudo authentication is needed...": "Überprüfung, ob sudo-Authentifizierung erforderlich ist..."
|
||||
"Checking whether sudo authentication is needed...": ""
|
||||
},
|
||||
"Checking...": {
|
||||
"Checking...": "Prüfung..."
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": "Wählen Sie, ob eine Desktop-App oder ein Befehl gestartet werden soll"
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Wählen Sie aus, welche Anzeigen dieses Widget anzeigen"
|
||||
},
|
||||
@@ -1710,7 +1650,7 @@
|
||||
"Connecting to Device": "Verbinde Gerät"
|
||||
},
|
||||
"Connecting to clipboard service...": {
|
||||
"Connecting to clipboard service...": "Verbindung zum Zwischenablagedienst wird hergestellt..."
|
||||
"Connecting to clipboard service...": ""
|
||||
},
|
||||
"Connecting...": {
|
||||
"Connecting...": "Verbinden..."
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Steuert die Deckkraft aller Popouts, Modals und deren Inhaltsebenen"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "Steuert Umrisse um weichgezeichnete Vordergrundkarten, Pillen und Benachrichtigungskarten"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "Steuert den Basis-Unschärferadius und den Versatz von Schatten"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "Steuert den äußeren Rand von protokoll-weichgezeichneten Fenstern"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Kritische Priorität"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Strg+Tab: Tab wechseln • Strg+S: Anpinnen/Lösen • Umschalt+Entf: Alles löschen • Esc: Schließen"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell ist einsatzbereit"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "Standard-Launcher-Kurzbefehl"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": "Standardmäßig wird geöffnet"
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Geräteverbindungen"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Gerätenamen aktualisiert"
|
||||
},
|
||||
@@ -2340,7 +2238,7 @@
|
||||
"Disabling WiFi...": "deaktiviere WLAN..."
|
||||
},
|
||||
"Disabling auto-login on startup...": {
|
||||
"Disabling auto-login on startup...": "Automatische Anmeldung beim Start wird deaktiviert..."
|
||||
"Disabling auto-login on startup...": ""
|
||||
},
|
||||
"Disc": {
|
||||
"Disc": "Scheibe"
|
||||
@@ -2406,7 +2304,7 @@
|
||||
"Display all priorities over fullscreen apps": "Zeige alle Prioritäten über Fullscreen-Anwendungen"
|
||||
},
|
||||
"Display and switch MangoWC layouts": {
|
||||
"Display and switch MangoWC layouts": "MangoWC-Layouts anzeigen und wechseln"
|
||||
"Display and switch MangoWC layouts": ""
|
||||
},
|
||||
"Display application icons in workspace indicators": {
|
||||
"Display application icons in workspace indicators": "Anwendungssymbole in Arbeitsbereichs-Indikatoren anzeigen"
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock & Launcher"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Dock Transparenz"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Dock-Sichtbarkeit"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "Dock-Rand, Transparenz und Rahmen"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "Kante, von der der Launcher hereingleitet"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "App bearbeiten"
|
||||
},
|
||||
@@ -2591,11 +2480,8 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "Text der Zwischenablage bearbeiten"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": "Bearbeite Änderungen an %1"
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
"Education": {
|
||||
"Education": "Bildung"
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Ende"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Vergrößern beim Drüberfahren"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "Alle 15 Minuten"
|
||||
},
|
||||
@@ -3111,7 +2991,7 @@
|
||||
"Failed to write autostart entry": "Autostart-Eintrag konnte nicht geschrieben werden"
|
||||
},
|
||||
"Failed to write outputs config.": {
|
||||
"Failed to write outputs config.": "Fehler beim Schreiben der Ausgabekonfiguration."
|
||||
"Failed to write outputs config.": ""
|
||||
},
|
||||
"Failed to write temp file for validation": {
|
||||
"Failed to write temp file for validation": "Temporäre Datei zur Validierung konnte nicht geschrieben werden"
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "Dateimanager"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "Dateimanager zum Öffnen des Papierkorbs. Wählen Sie „Benutzerdefiniert“, um einen eigenen Befehl einzugeben."
|
||||
},
|
||||
@@ -3237,19 +3114,19 @@
|
||||
"Float": "Schwebend"
|
||||
},
|
||||
"Float Anchor": {
|
||||
"Float Anchor": "Schwebender Anker"
|
||||
"Float Anchor": ""
|
||||
},
|
||||
"Float X": {
|
||||
"Float X": "Schwebend X"
|
||||
"Float X": ""
|
||||
},
|
||||
"Float Y": {
|
||||
"Float Y": "Schwebend Y"
|
||||
"Float Y": ""
|
||||
},
|
||||
"Floating": {
|
||||
"Floating": "Schwebend"
|
||||
},
|
||||
"Floating Position": {
|
||||
"Floating Position": "Schwebende Position"
|
||||
"Floating Position": ""
|
||||
},
|
||||
"Fluent": {
|
||||
"Fluent": "Fließend"
|
||||
@@ -3582,7 +3459,7 @@
|
||||
"Group": "Gruppe"
|
||||
},
|
||||
"Group Active Workspace": {
|
||||
"Group Active Workspace": "Aktiven Arbeitsbereich gruppieren"
|
||||
"Group Active Workspace": ""
|
||||
},
|
||||
"Group Workspace Apps": {
|
||||
"Group Workspace Apps": "Arbeitsbereich-Apps gruppieren"
|
||||
@@ -3945,7 +3822,7 @@
|
||||
"Inhibitable": "Unterdrückbar"
|
||||
},
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": {
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": "Ursprüngliche Position für schwebende Fenster. Geben Sie sowohl X als auch Y an; der Anker steuert, auf welche Ecke/Kante sie sich beziehen."
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": ""
|
||||
},
|
||||
"Initialised": {
|
||||
"Initialised": "Initialisiert"
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "Setzen Sie Ihren Sicherheitsschlüssel ein..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Installieren"
|
||||
},
|
||||
@@ -4053,7 +3927,7 @@
|
||||
"Invert on mode change": "Invertieren bei Moduswechsel"
|
||||
},
|
||||
"Invert touchpad scroll direction": {
|
||||
"Invert touchpad scroll direction": "Scrollrichtung des Touchpads umkehren"
|
||||
"Invert touchpad scroll direction": ""
|
||||
},
|
||||
"Iris Bloom": {
|
||||
"Iris Bloom": "Iris-Blüte"
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Änderungen beibehalten"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "Tippen Sie weiter"
|
||||
},
|
||||
@@ -4386,10 +4254,10 @@
|
||||
"Manages files and directories": "Verwaltet Dateien und Verzeichnisse"
|
||||
},
|
||||
"Mango Options": {
|
||||
"Mango Options": "Mango-Optionen"
|
||||
"Mango Options": ""
|
||||
},
|
||||
"Mango service not available": {
|
||||
"Mango service not available": "Mango-Dienst nicht verfügbar"
|
||||
"Mango service not available": ""
|
||||
},
|
||||
"MangoWC Layout Overrides": {
|
||||
"MangoWC Layout Overrides": "MangoWC-Layout-Überschreibungen"
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Manuelle Abstandsgröße"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Manuelles Anzeigen/Verstecken"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "Max. laufende Apps (0 = unbegrenzt)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Maximale Lautstärke"
|
||||
},
|
||||
@@ -4779,7 +4641,7 @@
|
||||
"Native: platform renderer (FreeType).": "Nativ: Plattform-Renderer (FreeType)."
|
||||
},
|
||||
"Natural Touchpad Scrolling": {
|
||||
"Natural Touchpad Scrolling": "Natürliches Scrollen (Touchpad)"
|
||||
"Natural Touchpad Scrolling": ""
|
||||
},
|
||||
"Navigate": {
|
||||
"Navigate": "Navigieren"
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Neuer Gruppenname..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Keine Helligkeitsgeräte verfügbar"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Keine Änderungen"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Keine aktuellen Einträge in der Zwischenablage gefunden"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "Keine Ergebnisse"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Keine Fensterregeln eingerichtet"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": "Rauschen"
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Notizblock Schriftart-Einstellungen"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Notizen Ausklappmenü"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Nichts"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "Offener Rahmen"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Öffnen Sie KDE Connect auf Ihrem Telefon"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Einfügen"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Pfad zu einer Videodatei oder einem Ordner mit Videos"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "Polkit-Integration ist deaktiviert. Die Benutzerverwaltung erfordert Polkit zur Rechteausweitung."
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "Popout-Schatten"
|
||||
},
|
||||
@@ -6114,7 +5949,7 @@
|
||||
"Refresh Weather": "Wetter aktualisieren"
|
||||
},
|
||||
"Refreshing...": {
|
||||
"Refreshing...": "Aktualisierung..."
|
||||
"Refreshing...": ""
|
||||
},
|
||||
"Regex": {
|
||||
"Regex": "Regex"
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Loslassen"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Plugin neu laden"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Letzten Benutzer merken"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Entfernen"
|
||||
},
|
||||
@@ -6246,7 +6075,7 @@
|
||||
"Requires DMS server with sysupdate capability": "Erfordert DMS-Server mit sysupdate-Funktion"
|
||||
},
|
||||
"Requires MangoWC compositor": {
|
||||
"Requires MangoWC compositor": "Erfordert MangoWC-Compositor"
|
||||
"Requires MangoWC compositor": ""
|
||||
},
|
||||
"Requires a newer version of Quickshell": {
|
||||
"Requires a newer version of Quickshell": "Erfordert eine neuere Version von Quickshell"
|
||||
@@ -6279,10 +6108,10 @@
|
||||
"Resize Widget": "Widget-Größe ändern"
|
||||
},
|
||||
"Resize on Border": {
|
||||
"Resize on Border": "Größenänderung am Rand"
|
||||
"Resize on Border": ""
|
||||
},
|
||||
"Resize windows by dragging their edges with the mouse": {
|
||||
"Resize windows by dragging their edges with the mouse": "Fenstergröße durch Ziehen der Ränder mit der Maus ändern"
|
||||
"Resize windows by dragging their edges with the mouse": ""
|
||||
},
|
||||
"Resolution & Refresh": {
|
||||
"Resolution & Refresh": "Auflösung & Bildwiederholrate"
|
||||
@@ -6393,7 +6222,7 @@
|
||||
"Running Apps Settings": "Einstellungen für laufende Applikationen"
|
||||
},
|
||||
"Running greeter sync...": {
|
||||
"Running greeter sync...": "Greeter-Synchronisierung wird ausgeführt..."
|
||||
"Running greeter sync...": ""
|
||||
},
|
||||
"Running in terminal": {
|
||||
"Running in terminal": "Läuft im Terminal"
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Speichert..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Skalierung"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Benachrichtigungsregeln festlegen"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "Einstellung"
|
||||
},
|
||||
@@ -7013,11 +6833,8 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Zeige Applikationen von Arbeitsbereich"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": "Alle 9 Tags anzeigen anstatt nur belegte Tags"
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
"Show an outline ring around the focused workspace indicator": {
|
||||
"Show an outline ring around the focused workspace indicator": "Einen Umrissring um die Anzeige des fokussierten Arbeitsbereichs anzeigen"
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "Benachrichtigungen stummschalten"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Größe"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": "Überspringen Sie das Greeter-Passwort nach dem Booten, bis Sie sich abmelden. Die Entsperrung des Sperrbildschirms bleibt unverändert. Tritt nach der Synchronisierung beim nächsten Neustart in Kraft."
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Klein"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Zusammenfassung"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Sonnenaufgang"
|
||||
},
|
||||
@@ -7455,7 +7263,7 @@
|
||||
"Tab/Shift+Tab: Nav • ←→↑↓: Grid Nav • Enter/Space: Select": "Tab/Shift+Tab: Navigation • ←→↑↓: Grid Nav • Enter/Leertaste: Auswählen"
|
||||
},
|
||||
"Tags": {
|
||||
"Tags": "Tags"
|
||||
"Tags": ""
|
||||
},
|
||||
"Tags: %1": {
|
||||
"Tags: %1": "Tags: %1"
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Zeit abgelaufen"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Zeitüberschreitung für Benachrichtigungen mit kritischer Priorität"
|
||||
},
|
||||
@@ -7686,10 +7491,7 @@
|
||||
"Title": "Titel"
|
||||
},
|
||||
"Title (optional)": {
|
||||
"Title (optional)": "Titel (optional)"
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Titel-Regex (optional)"
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Nutze Raster Layout"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Positionserkennung durch IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "Verwendet die spotlight-bar IPC-Aktion und öffnet immer die minimale Leiste."
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "Verwendet globale Monospace-Schriftart aus Einstellungen → Personalisierung"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Verwendet geteilte Einstellungen von Gamma Control"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Sichtbarkeit"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Visuelle Effekte"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Widget Verwaltung"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Widget-Umriss"
|
||||
},
|
||||
@@ -8418,7 +8205,7 @@
|
||||
"Widgets": "Widgets"
|
||||
},
|
||||
"Widgets & Notifications": {
|
||||
"Widgets & Notifications": "Widgets & Benachrichtigungen"
|
||||
"Widgets & Notifications": ""
|
||||
},
|
||||
"Widgets, layout, style": {
|
||||
"Widgets, layout, style": "Widgets, Layout, Stil"
|
||||
@@ -8433,7 +8220,7 @@
|
||||
"Width of the widget outline in pixels": "Breite des Widget-Umrisses in Pixeln"
|
||||
},
|
||||
"Width of window border": {
|
||||
"Width of window border": "Breite des Fensterrahmens"
|
||||
"Width of window border": ""
|
||||
},
|
||||
"Width of window border and focus ring": {
|
||||
"Width of window border and focus ring": "Breite von Fensterrahmen und Fokusring"
|
||||
@@ -8475,7 +8262,7 @@
|
||||
"Wipe": "Wischen"
|
||||
},
|
||||
"Working...": {
|
||||
"Working...": "Wird ausgeführt..."
|
||||
"Working...": ""
|
||||
},
|
||||
"Workspace": {
|
||||
"Workspace": "Arbeitsbereich"
|
||||
@@ -8511,7 +8298,7 @@
|
||||
"Write:": "Schreiben:"
|
||||
},
|
||||
"X": {
|
||||
"X": "X"
|
||||
"X": ""
|
||||
},
|
||||
"X Axis": {
|
||||
"X Axis": "X-Achse"
|
||||
@@ -8526,7 +8313,7 @@
|
||||
"Xray blurs only the wallpaper (efficient) and is the default when Blur is on. Set Xray to Off for regular full blur of everything beneath the window (more expensive).": "X-Ray lässt nur das Hintergrundbild verschwimmen (effizient) und ist die Standardeinstellung, wenn Weichzeichnen aktiviert ist. Deaktivieren Sie X-Ray für ein normales, vollständiges Weichzeichnen von allem unter dem Fenster (ressourcenintensiver)."
|
||||
},
|
||||
"Y": {
|
||||
"Y": "Y"
|
||||
"Y": ""
|
||||
},
|
||||
"Y Axis": {
|
||||
"Y Axis": "Y-Achse"
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "Hervorgehoben"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "zuletzt gesehen %1"
|
||||
},
|
||||
@@ -8655,10 +8439,10 @@
|
||||
"loginctl not available - lock integration requires DMS socket connection": "loginctl nicht verfügbar – Sperrintegration erfordert DMS-Socket-Verbindung"
|
||||
},
|
||||
"mango: config reloaded": {
|
||||
"mango: config reloaded": "mango: Konfiguration neu geladen"
|
||||
"mango: config reloaded": ""
|
||||
},
|
||||
"mango: failed to reload config": {
|
||||
"mango: failed to reload config": "mango: Fehler beim Neuladen der Konfiguration"
|
||||
"mango: failed to reload config": ""
|
||||
},
|
||||
"mangowc Discord Server": {
|
||||
"mangowc Discord Server": "mangowc Discord-Server"
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 dia"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 dispositivo conectado"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": ""
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 minuto"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 minutos"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": ""
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": ""
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": ""
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": ""
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": ""
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 minutos"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": ""
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": ""
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": ""
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": ""
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Auto (Ancho)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Localización automática"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Márgenes automáticos en pop‑ups"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": ""
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Limpiar automáticamente despues"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Guardando automáticamente..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Bloquear pantalla cuando el sistema se vaya a suspender"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": ""
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Configuración de barras"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": ""
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": ""
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Aplicar desenfoque en la vista general de niri"
|
||||
},
|
||||
"Body": {
|
||||
"Body": ""
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": ""
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": ""
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Cámara"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Elija qué pantallas muestran este widget"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Controla la opacidad de todas las ventanas emergentes, modales y sus capas de contenido."
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": ""
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": ""
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": ""
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Prioridad Crítica"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": ""
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell está listo para utilizarse"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Conexiones de dispositivos"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": ""
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock y Lanzador"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Transparencia del dock"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Visibilidad del dock"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": ""
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": ""
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": ""
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Final"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": ""
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": ""
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": ""
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": ""
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": ""
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Instalar"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Mantener cambios"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": ""
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Tamaño de separación manual"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Mostrar/Ocultar manualmente"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": ""
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": ""
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": ""
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "No hay dispositivos de brillo disponibles"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Sin cambios"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": ""
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": ""
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": ""
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Ajustes del bloc de notas"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Bloc de notas"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": ""
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": ""
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": ""
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": ""
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": ""
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": ""
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": ""
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Reiniciar complemento"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": ""
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Remover"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": ""
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Escala"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": ""
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": ""
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Mostrar aplicaciones en el espacio de trabajo"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": ""
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Tamaño"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": ""
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": ""
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Amanecer"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Tiempo agotado"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Tiempo de espera para notificaciones de prioridad crítica"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": ""
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Usar diseño en cuadrícula"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Usar la localización de la IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": ""
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": ""
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Visibilidad"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": ""
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Gestión de widgets"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Contorno en widgets"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": ""
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": ""
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "۱ روز"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 دستگاه متصل"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "۱ ساعت و نیم"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "۱ دقیقه"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "۱۰ دقیقه"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "۱۵ دقیقه"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "۱۵ دقیقه"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "۳۰ دقیقه"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "۳۰ دقیقه"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "۴۵ ثانیه"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "۵ دقیقه"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "افزودن با آدرس"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "کاربر جدید را به گروه %1 اضافه کنید تا بتواند dms greeter sync --profile را اجرا کند."
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "مجاز"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "اجازه بده کلیک ها از ابزارک عبور کنند"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "حداقل یک خروجی باید فعال بماند"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "پیوست"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "خودکار (عریض)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "موقعیت مکانی خودکار"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "فاصله پاپآپ خودکار"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "حالت خودکار فعال است. انتخاب پروفایل دستی غیرفعال میباشد."
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "پاککردن خودکار پس از"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "درحال ذخیره خودکار..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "صفحه را هنگام آمادهشدن سیستم برای تعلیق به صورت خودکار قفل کن"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "خودکارسازی"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "پیکربندی نوار"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "سایه نوارها"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "پسزمینه پشت نوارها، پاپآپها، مودالها و اعلانها را تار کن. به پشتیبانی و پیکربندی کامپازیتور نیاز دارد."
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "هنگامی که نمای کلی niri باز است تصویر پسزمینه را تار کن"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "بدنه"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "پررنگ"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "گاهشمار"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "دوربین"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "انتخاب کنید که کدام نمایشگرها این ابزارک را نشان دهند"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "میزان شفافیت همه پاپآپها، مودالها و لایههای محتوای آنها را کنترل میکند"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "خط بیرونی دور کارتهای پیشزمینه، برچسبهای گرد و کارتهای اعلان تار را کنترل میکند"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "شعاع تاری پایه و آفست سایه را کنترل میکند"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "لبه بیرونی پنجرههای تار شده با پروتکل را کنترل میکند"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "اولویت حیاتی"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab: جابجایی بین تبها • Ctrl+S: سنجاق/برداشتن سنجاق • Shift+Del: پاک کردن همه • Esc: بستن"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "نوار دَنک"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "دَنک متریال شل آماده استفاده میباشد"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "میانبر پیشفرض لانچر"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "اتصالهای دستگاه"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "نام دستگاهها بروز شدند"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "داک و لانچر"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "شفافیت داک"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "وضعیت نمایش داک"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "فاصله داخلی، شفافیت و حاشیه داک"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "لبهای که لانچر از آن بیرون میلغزد"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "ویرایش برنامه"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "ویرایش متن کلیپبورد"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "پایان"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "بزرگنمایی با اشاره"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "اترنت"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "هر ۱۵ دقیقه"
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "برنامه مدیریت فایل"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "مدیر فایل استفاده شده برای زبالهدان. «سفارشی» را انتخاب کرده تا دستور خود را وارد کنید."
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "کلید امنیتی خود را وارد کنید..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "نصب"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "حفظ تغییرات"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "به تایپ کردن ادامه دهید"
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "اندازه فاصله دستی"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "نمایش/پنهان دستی"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "بیشینه برنامههای درحال اجرا (۰ = نامحدود)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "حجم صدای بیشینه"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "نام جدید گروه..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "هیچ دستگاه روشنایی موجود نیست"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "بدون تغییرات"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "هیچ مدخل کلیپبورد اخیری یافت نشد"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "بدون نتیجه"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "هیچ قاعده پنجرهای پیکربندی نشده"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "تنظیمات دفترچه یادداشت"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "دفترچه یادداشت کشویی"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "هیچ"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "باز کردن قاب"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "برنامه KDE Connect را در گوشی خود باز کنید"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "الصاق"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "مسیر به فایل ویدئو یا پوشهای که دارای ویدئوها است"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "یکپارچهسازی polkit غیرفعال است. مدیریت کاربر برای بالابردن دسترسیها نیاز به polkit دارد."
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "سایه پاپآپها"
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "رها کردن"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "بارگذاری مجدد افزونه"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "آخرین کاربر را به خاطر بسپار"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "حذف"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "درحال ذخیره..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "بزرگنمایی"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "تنظیم قوانین اعلانها"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": ""
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "نمایش برنامههای محیطکار"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "بیصدا کردن اعلانها"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "اندازه"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "کوچک"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "خلاصه"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "طلوع"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "زمان تمام شد"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "وقفه اعلانها با اولویت حیاتی"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "رجکس عنوان (اختیاری)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "استفاده از چیدمان جدولی"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "استفاده از موقعیت مکانی IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "از IPC اقدام نوار اسپاتلایت استفاده میکند و همیشه نوار کمینه را باز میکند."
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "استفاده از قلم monospace سراسری از تنظیمات ← شخصیسازی"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "با استفاده از تنظیمات مشترک کنترل گاما"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "دید"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "افکتهای بصری"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "مدیریت ابزارکها"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "خط بیرونی ابزارک"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "پیشنهادی"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "آخرین بازدید: %1"
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 jour"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 appareil connecté"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 heure et 30 minutes"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 minute"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 minutes"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": ""
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 minutes"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": ""
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 minutes"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 secondes"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 minutes"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Ajouter par adresse"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Autoriser les clics à travers le widget"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": ""
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "Attacher"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Auto (large)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Localisation automatique"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Espacements automatiques des fenêtres contextuelles"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": ""
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Nettoyage automatique après"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Sauvegarde automatique..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Verrouiller automatiquement l’écran lorsque le système se prépare à se mettre en veille"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Automatisation"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Configurations de la barre"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Ombres de barre"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": ""
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Flouter le fond d’écran lorsque la vue d’ensemble de Niri est ouverte"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Corps"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": ""
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": ""
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Caméra"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Choisir les écrans sur lesquels afficher ce widget"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Contrôle l’opacité de toutes les fenêtres contextuelles, modales et de leurs couches de contenu"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": ""
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": ""
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": ""
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Priorité critique"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": ""
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell est prêt à l’emploi"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Connexions des périphériques"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Noms des appareils mis à jour"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock et lanceur"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Transparence du dock"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Visibilité du dock"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": ""
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": ""
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "Editer appli"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Fin"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Élargir lors du survol"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": ""
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": ""
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": ""
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": ""
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Installer"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Conserver les modifications"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": ""
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Taille de l’espacement manuel"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Afficher / masquer manuellement"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "Nombre maximum d'applis lancées (0 = illimité)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Volume max"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Nom du nouveau groupe..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Aucun périphérique de réglage de la luminosité disponible"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Aucune modification"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Aucune entrée récente trouvée dans le presse-papier"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": ""
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Aucune règle de fenêtre configurée"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Paramètres de police du bloc-notes"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Panneau du bloc-notes"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Rien"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": ""
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Ouvrir KDE Connect sur votre téléphone"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Coller"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Chemin vers un fichier vidéo ou dossier contenant des vidéos"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": ""
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Version"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Recharger le module"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Se souvenir du dernier utilisateur"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Supprimer"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Sauvegarde..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Échelle"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Définir les règles de notification"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": ""
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Afficher les applications de l’espace de travail"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": ""
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Taille"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Petit"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Résumé"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Lever du soleil"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Temps écoulé"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Durée d’affichage des notifications critiques"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Regex du titre (optionnelle)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Utiliser une disposition en grille"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Utiliser la localisation IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": ""
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Utiliser les réglages partagés de contrôle Gamma"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Visibilité"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Effets visuels"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Gestion des widgets"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Contour du widget"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "À la une"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": ""
|
||||
},
|
||||
|
||||
@@ -81,7 +81,7 @@
|
||||
"%1 online": "%1 מקוונים"
|
||||
},
|
||||
"%1 tasks": {
|
||||
"%1 tasks": "%1 משימות"
|
||||
"%1 tasks": ""
|
||||
},
|
||||
"%1 update": {
|
||||
"%1 update": "%1 עדכון"
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "יום אחד"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "התקן אחד מחובר"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "שעה וחצי (ו30 דקות)"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "דקה אחת"
|
||||
},
|
||||
@@ -159,10 +153,7 @@
|
||||
"1 second": "שנייה אחת"
|
||||
},
|
||||
"1 task": {
|
||||
"1 task": "משימה אחת"
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
"1 task": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 דקות"
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 דקות"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 דקות"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 דקות"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 דקות"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 שניות"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 דקות"
|
||||
},
|
||||
@@ -459,7 +441,7 @@
|
||||
"Add a custom prefix to all application launches. This can be used for things like 'uwsm-app', 'systemd-run', or other command wrappers.": "הוסף/י קידומת מותאמת אישית לכל הפעלות האפליקציות. ניתן להשתמש בזה עבור דברים כמו 'uwsm-app', 'systemd-run', או עוטפי פקודות אחרים."
|
||||
},
|
||||
"Add a task...": {
|
||||
"Add a task...": "הוסף/י משימה..."
|
||||
"Add a task...": ""
|
||||
},
|
||||
"Add and configure widgets that appear on your desktop": {
|
||||
"Add and configure widgets that appear on your desktop": "הוסף/י והגדר/י ווידג׳טים שמופיעים על שולחן העבודה שלך"
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "הוספה לפי כתובת"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": "הוסף/י התאמה"
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "הוסף/י את המשתמש/ת החדש/ה לקבוצה %1 כדי שיוכלו להריץ את הפקודה dms greeter sync --profile."
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "אפשר/י"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "אפשר/י ללחיצות לעבור מבעד לווידג׳ט"
|
||||
},
|
||||
@@ -540,7 +513,7 @@
|
||||
"Already on that session": "כבר בהפעלה זו"
|
||||
},
|
||||
"Also group repeated application icons on the active workspace": {
|
||||
"Also group repeated application icons on the active workspace": "קבץ/י גם סמלי אפליקציות שחוזרים על עצמם בסביבת העבודה הפעילה"
|
||||
"Also group repeated application icons on the active workspace": ""
|
||||
},
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": {
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": "Alt+←/Backspace: חזרה • F1/I: מידע על הקובץ • F10: עזרה • Esc: סגירה"
|
||||
@@ -585,7 +558,7 @@
|
||||
"Analyzing configuration...": "מנתח תצורה..."
|
||||
},
|
||||
"Anchor": {
|
||||
"Anchor": "עוגן"
|
||||
"Anchor": ""
|
||||
},
|
||||
"Animation Duration": {
|
||||
"Animation Duration": "משך זמן לאנימציה"
|
||||
@@ -612,7 +585,7 @@
|
||||
"App ID": "App ID"
|
||||
},
|
||||
"App ID (e.g. firefox)": {
|
||||
"App ID (e.g. firefox)": "App ID (לדוגמה firefox)"
|
||||
"App ID (e.g. firefox)": ""
|
||||
},
|
||||
"App ID Substitutions": {
|
||||
"App ID Substitutions": "החלפת ID לאפליקציות"
|
||||
@@ -669,10 +642,10 @@
|
||||
"Apply warm color temperature to reduce eye strain. Use automation settings below to control when it activates.": "הגדרת טמפרטורת צבע חמה כדי להפחית מאמץ בעיניים. השתמש/י בהגדרות האוטומציה למטה כדי לשלוט מתי ההגדרה מופעלת."
|
||||
},
|
||||
"Applying authentication changes...": {
|
||||
"Applying authentication changes...": "מחיל שינויי אימות..."
|
||||
"Applying authentication changes...": ""
|
||||
},
|
||||
"Applying auto-login on startup...": {
|
||||
"Applying auto-login on startup...": "מחיל התחברות אוטומטית בהפעלה..."
|
||||
"Applying auto-login on startup...": ""
|
||||
},
|
||||
"Apps": {
|
||||
"Apps": "אפליקציות"
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "לפחות פלט אחד חייב להישאר מופעל"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "חבר/י"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "אוטומטי (רחב)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "מיקום אוטומטי"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "מרווחי חלוניות קופצות אוטומטיים"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "מצב אוטומטי מופעל. בחירת פרופיל ידנית מושבתת."
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "ניקוי אוטומטי אחרי"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": "התחברות אוטומטית בהפעלה"
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "שומר אוטומטית..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "נעילה אוטומטית של המסך כשהמערכת מתכוננת למצב השהיה"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "אוטומציה"
|
||||
},
|
||||
@@ -987,17 +942,14 @@
|
||||
"Balanced palette with focused accents (default).": "פלטה מאוזנת עם דגשים ממוקדים (ברירת מחדל)."
|
||||
},
|
||||
"Bar": {
|
||||
"Bar": "סרגל"
|
||||
"Bar": ""
|
||||
},
|
||||
"Bar %1": {
|
||||
"Bar %1": "סרגל %1"
|
||||
"Bar %1": ""
|
||||
},
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "תצורות סרגלים"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "הצללות סרגל"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "טשטש/י את הרקע מאחורי סרגלים, חלונות קופצים, מודלים והתראות. דורש תמיכה והגדרה של הקומפוזיטור."
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "טשטש/י את הרקע כאשר הסקירה של Niri פתוחה"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "גוף"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "מודגש"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "יומן"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "מצלמה"
|
||||
},
|
||||
@@ -1338,7 +1281,7 @@
|
||||
"Checking for updates...": "בודק עדכונים..."
|
||||
},
|
||||
"Checking whether sudo authentication is needed...": {
|
||||
"Checking whether sudo authentication is needed...": "בודק אם נדרש אימות עם sudo..."
|
||||
"Checking whether sudo authentication is needed...": ""
|
||||
},
|
||||
"Checking...": {
|
||||
"Checking...": "בודק..."
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": "בחר/י האם להפעיל אפליקציית שולחן עבודה או פקודה"
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "בחר/י באילו מסכים יוצג ווידג׳ט זה"
|
||||
},
|
||||
@@ -1710,7 +1650,7 @@
|
||||
"Connecting to Device": "מתחבר להתקן"
|
||||
},
|
||||
"Connecting to clipboard service...": {
|
||||
"Connecting to clipboard service...": "מתחבר לשירות לוח ההעתקה..."
|
||||
"Connecting to clipboard service...": ""
|
||||
},
|
||||
"Connecting...": {
|
||||
"Connecting...": "מתחבר..."
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "שולט בשקיפות של כל החלונות הקופצים, המודלים ושכבות התוכן שלהם"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "שולט בקווי המתאר מסביב לכרטיסי רקע קדמי מטושטשים, כפתורים וכרטיסי התראות"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "שולט ברדיוס הטשטוש הבסיסי ובהיסט של הצללים"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "שולט בקצה החיצוני של חלונות המטושטשים על ידי הפרוטוקול"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "עדיפות קריטית"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab: החלפת כרטיסיה • Ctrl+S: הצמדה/ביטול הצמדה • Shift+Del: ניקוי הכל • Esc: סגירה"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "Dank Bar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell מוכן לשימוש"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "קיצור מקלדת למשגר ברירת המחדל"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": "פתיחה כברירת מחדל"
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "חיבורי התקנים"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "שמות ההתקנים עודכנו"
|
||||
},
|
||||
@@ -2340,7 +2238,7 @@
|
||||
"Disabling WiFi...": "משבית WiFi..."
|
||||
},
|
||||
"Disabling auto-login on startup...": {
|
||||
"Disabling auto-login on startup...": "משבית התחברות אוטומטית בהפעלה..."
|
||||
"Disabling auto-login on startup...": ""
|
||||
},
|
||||
"Disc": {
|
||||
"Disc": "דיסק"
|
||||
@@ -2406,7 +2304,7 @@
|
||||
"Display all priorities over fullscreen apps": "הצג/י את כל ההתראות מעל אפליקציות במסך מלא"
|
||||
},
|
||||
"Display and switch MangoWC layouts": {
|
||||
"Display and switch MangoWC layouts": "הצג/י והחלף/י פריסות של MangoWC"
|
||||
"Display and switch MangoWC layouts": ""
|
||||
},
|
||||
"Display application icons in workspace indicators": {
|
||||
"Display application icons in workspace indicators": "הצג/י סמלי אפליקציות במצייני סביבת העבודה"
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "משגר וDock"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "שקיפות הDock"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "נראות הDock"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "שוליים, שקיפות ומסגרת הDock"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "הקצה שממנו המשגר מחליק"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "ערוך/ערכי אפליקציה"
|
||||
},
|
||||
@@ -2591,11 +2480,8 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "ערוך/ערכי טקסט מלוח ההעתקה"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": "עורך שינויים ב-%1"
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
"Education": {
|
||||
"Education": "חינוך"
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "סוף"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "הגדל/י בריחוף"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "כל 15 דקות"
|
||||
},
|
||||
@@ -3111,7 +2991,7 @@
|
||||
"Failed to write autostart entry": "כתיבת רשומת ההפעלה האוטומטית נכשלה"
|
||||
},
|
||||
"Failed to write outputs config.": {
|
||||
"Failed to write outputs config.": "כתיבת קובץ ההגדרה לפלט התצוגה נכשלה."
|
||||
"Failed to write outputs config.": ""
|
||||
},
|
||||
"Failed to write temp file for validation": {
|
||||
"Failed to write temp file for validation": "כתיבת קובץ זמני לאימות נכשלה"
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "מנהל קבצים"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "מנהל הקבצים שבו נעשה שימוש כדי לפתוח את האשפה. בחר/י \"מותאם אישית\" כדי להזין פקודה משלך."
|
||||
},
|
||||
@@ -3237,19 +3114,19 @@
|
||||
"Float": "צף"
|
||||
},
|
||||
"Float Anchor": {
|
||||
"Float Anchor": "עוגן צף"
|
||||
"Float Anchor": ""
|
||||
},
|
||||
"Float X": {
|
||||
"Float X": "X צף"
|
||||
"Float X": ""
|
||||
},
|
||||
"Float Y": {
|
||||
"Float Y": "Y צף"
|
||||
"Float Y": ""
|
||||
},
|
||||
"Floating": {
|
||||
"Floating": "צף"
|
||||
},
|
||||
"Floating Position": {
|
||||
"Floating Position": "מיקום צף"
|
||||
"Floating Position": ""
|
||||
},
|
||||
"Fluent": {
|
||||
"Fluent": "Fluent"
|
||||
@@ -3582,7 +3459,7 @@
|
||||
"Group": "קבוצה"
|
||||
},
|
||||
"Group Active Workspace": {
|
||||
"Group Active Workspace": "קיבוץ בסביבת העבודה הפעילה"
|
||||
"Group Active Workspace": ""
|
||||
},
|
||||
"Group Workspace Apps": {
|
||||
"Group Workspace Apps": "קיבוץ האפליקציות של סביבת העבודה"
|
||||
@@ -3945,7 +3822,7 @@
|
||||
"Inhibitable": "ניתן לעיכוב"
|
||||
},
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": {
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": "מיקום התחלתי לחלונות צפים. הגדר/י גם את X וגם את Y; העוגן שולט לאיזו פינה/קצה הם מתייחסים."
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": ""
|
||||
},
|
||||
"Initialised": {
|
||||
"Initialised": "אותחל"
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "הכנס/י את מפתח האבטחה שלך..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "התקן/י"
|
||||
},
|
||||
@@ -4053,7 +3927,7 @@
|
||||
"Invert on mode change": "היפוך בעת שינוי מצב"
|
||||
},
|
||||
"Invert touchpad scroll direction": {
|
||||
"Invert touchpad scroll direction": "הפוך/הפכי את כיוון הגלילה של משטח המגע"
|
||||
"Invert touchpad scroll direction": ""
|
||||
},
|
||||
"Iris Bloom": {
|
||||
"Iris Bloom": "פריחת האיריס"
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "שמור/י שינויים"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "המשך/המשיכי להקליד"
|
||||
},
|
||||
@@ -4386,10 +4254,10 @@
|
||||
"Manages files and directories": "מנהל קבצים ותיקיות"
|
||||
},
|
||||
"Mango Options": {
|
||||
"Mango Options": "אפשרויות Mango"
|
||||
"Mango Options": ""
|
||||
},
|
||||
"Mango service not available": {
|
||||
"Mango service not available": "שירות Mango אינו זמין"
|
||||
"Mango service not available": ""
|
||||
},
|
||||
"MangoWC Layout Overrides": {
|
||||
"MangoWC Layout Overrides": "דריסות פריסה של MangoWC"
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "גודל מרווח ידני"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "הצגה/הסתרה ידנית"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "מקסימום אפליקציות פועלות (0 = ללא הגבלה)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "עוצמה מקסימלית"
|
||||
},
|
||||
@@ -4779,7 +4641,7 @@
|
||||
"Native: platform renderer (FreeType).": "מובנה: מעבד הפלטפורמה המובנה (FreeType)."
|
||||
},
|
||||
"Natural Touchpad Scrolling": {
|
||||
"Natural Touchpad Scrolling": "גלילה טבעית במשטח המגע"
|
||||
"Natural Touchpad Scrolling": ""
|
||||
},
|
||||
"Navigate": {
|
||||
"Navigate": "ניווט"
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "ניו יורק, ניו יורק"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "שם לקבוצה החדשה..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "אין התקני בהירות זמינים"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "אין שינויים"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "לא נמצאו רשומות לוח ההעתקה אחרונות"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "אין תוצאות"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "לא הוגדרו חוקי חלון"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": "רעש"
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "הגדרות גופן של הפנקס"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "החלקה של הפנקס"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "כלום"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "פתח/י מסגרת"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "פתח/י את KDE Connect בטלפון שלך"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "הדבק/י"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "נתיב לקובץ וידאו או תיקייה המכילה סרטוני וידאו"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "האינטגרציה עם Polkit מושבתת. ניהול משתמשים דורש את Polkit לצורך עדכון ההרשאות."
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "הצללות של חלונות קופצים"
|
||||
},
|
||||
@@ -6114,7 +5949,7 @@
|
||||
"Refresh Weather": "רענן/י מזג אוויר"
|
||||
},
|
||||
"Refreshing...": {
|
||||
"Refreshing...": "מרענן..."
|
||||
"Refreshing...": ""
|
||||
},
|
||||
"Regex": {
|
||||
"Regex": "Regex"
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "שחרור"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "טען/י תוסף מחדש"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "זכירת המשתמש האחרון"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "הסרה"
|
||||
},
|
||||
@@ -6246,7 +6075,7 @@
|
||||
"Requires DMS server with sysupdate capability": "נדרש שרת DMS עם יכולת עדכון מערכת (sysupdate)"
|
||||
},
|
||||
"Requires MangoWC compositor": {
|
||||
"Requires MangoWC compositor": "קומפוזיטור MangoWC נדרש"
|
||||
"Requires MangoWC compositor": ""
|
||||
},
|
||||
"Requires a newer version of Quickshell": {
|
||||
"Requires a newer version of Quickshell": "נדרשת גרסה חדשה יותר של Quickshell"
|
||||
@@ -6279,10 +6108,10 @@
|
||||
"Resize Widget": "שינוי גודל הווידג׳ט"
|
||||
},
|
||||
"Resize on Border": {
|
||||
"Resize on Border": "שינוי גודל במסגרת"
|
||||
"Resize on Border": ""
|
||||
},
|
||||
"Resize windows by dragging their edges with the mouse": {
|
||||
"Resize windows by dragging their edges with the mouse": "שנה/י גודל חלונות על ידי גרירת הקצוות שלהם עם העכבר"
|
||||
"Resize windows by dragging their edges with the mouse": ""
|
||||
},
|
||||
"Resolution & Refresh": {
|
||||
"Resolution & Refresh": "רזולוציה ורענון"
|
||||
@@ -6393,7 +6222,7 @@
|
||||
"Running Apps Settings": "הגדרות אפליקציות פעילות"
|
||||
},
|
||||
"Running greeter sync...": {
|
||||
"Running greeter sync...": "מריץ סנכרון greeter..."
|
||||
"Running greeter sync...": ""
|
||||
},
|
||||
"Running in terminal": {
|
||||
"Running in terminal": "פועל במסוף"
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "שומר/ת..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "קנה מידה"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "הגדר/י חוקים להתראות"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "הגדרה"
|
||||
},
|
||||
@@ -7013,11 +6833,8 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "הצגת אפליקציות בסביבת העבודה"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": "הצג/י את כל 9 התגיות במקום רק תגיות בשימוש"
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
"Show an outline ring around the focused workspace indicator": {
|
||||
"Show an outline ring around the focused workspace indicator": "הצג/י טבעת מתאר סביב המחוון של סביבת העבודה הממוקדת"
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "השתק/י התראות"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "גודל"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": "דלג/י על סיסמת מסך ההתחברות לאחר ההפעלה עד להתנתקות. פתיחת מסך הנעילה נשארת ללא שינוי. ייכנס לתוקף בהפעלה מחדש הבאה לאחר סנכרון."
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "קטן"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "סיכום"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "זריחה"
|
||||
},
|
||||
@@ -7455,7 +7263,7 @@
|
||||
"Tab/Shift+Tab: Nav • ←→↑↓: Grid Nav • Enter/Space: Select": "Tab/Shift+Tab: ניווט • ←→↑↓: ניווט ברשת • Enter/Space: בחירה"
|
||||
},
|
||||
"Tags": {
|
||||
"Tags": "תגיות"
|
||||
"Tags": ""
|
||||
},
|
||||
"Tags: %1": {
|
||||
"Tags: %1": "תגיות: %1"
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "הזמן אזל"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "הזמן שמוקצב להתראות בעדיפות קריטית"
|
||||
},
|
||||
@@ -7686,10 +7491,7 @@
|
||||
"Title": "כותרת"
|
||||
},
|
||||
"Title (optional)": {
|
||||
"Title (optional)": "כותרת (אופציונלי)"
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Title regex (אופציונלי)"
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "שימוש בפריסת רשת"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "שימוש במיקום לפי כתובת IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "משתמש בפעולת הIPC של spotlight-bar ותמיד פותח את הסרגל המינימלי."
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "משתמש בגופן ברוחב קבוע גלובלי מהגדרות ← התאמה אישית"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "ההגדרות משותפות עם בקרת גאמה"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "נראות"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "אפקטים ויזואליים"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "ניהול ווידג׳טים"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "מתאר לווידג׳טים"
|
||||
},
|
||||
@@ -8418,7 +8205,7 @@
|
||||
"Widgets": "ווידג׳טים"
|
||||
},
|
||||
"Widgets & Notifications": {
|
||||
"Widgets & Notifications": "ווידג׳טים והתראות"
|
||||
"Widgets & Notifications": ""
|
||||
},
|
||||
"Widgets, layout, style": {
|
||||
"Widgets, layout, style": "ווידג׳טים, פריסה, סגנון"
|
||||
@@ -8433,7 +8220,7 @@
|
||||
"Width of the widget outline in pixels": "רוחב של קו המתאר של הווידג׳ט בפיקסלים"
|
||||
},
|
||||
"Width of window border": {
|
||||
"Width of window border": "רוחב מסגרת החלון"
|
||||
"Width of window border": ""
|
||||
},
|
||||
"Width of window border and focus ring": {
|
||||
"Width of window border and focus ring": "רוחב מסגרת חלון וטבעת מיקוד"
|
||||
@@ -8475,7 +8262,7 @@
|
||||
"Wipe": "ניגוב"
|
||||
},
|
||||
"Working...": {
|
||||
"Working...": "עובד..."
|
||||
"Working...": ""
|
||||
},
|
||||
"Workspace": {
|
||||
"Workspace": "סביבת עבודה"
|
||||
@@ -8511,7 +8298,7 @@
|
||||
"Write:": "כתיבה:"
|
||||
},
|
||||
"X": {
|
||||
"X": "X"
|
||||
"X": ""
|
||||
},
|
||||
"X Axis": {
|
||||
"X Axis": "ציר X"
|
||||
@@ -8526,7 +8313,7 @@
|
||||
"Xray blurs only the wallpaper (efficient) and is the default when Blur is on. Set Xray to Off for regular full blur of everything beneath the window (more expensive).": "רנטגן (xray) מטשטש רק את תמונת הרקע (חסכוני) וזוהי ברירת המחדל כאשר הטשטוש פועל. הגדר/י את ״רנטגן״ ככבוי לקבלת טשטוש מלא רגיל של כל מה שנמצא מתחת לחלון (זולל יותר משאבים)."
|
||||
},
|
||||
"Y": {
|
||||
"Y": "Y"
|
||||
"Y": ""
|
||||
},
|
||||
"Y Axis": {
|
||||
"Y Axis": "ציר Y"
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "מומלץ"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "נראה/תה לאחרונה %1"
|
||||
},
|
||||
@@ -8655,10 +8439,10 @@
|
||||
"loginctl not available - lock integration requires DMS socket connection": "loginctl אינו זמין, אינטגרציה של הנעילה דורשת חיבור socket לDMS"
|
||||
},
|
||||
"mango: config reloaded": {
|
||||
"mango: config reloaded": "mango: ההגדרות נטענו מחדש"
|
||||
"mango: config reloaded": ""
|
||||
},
|
||||
"mango: failed to reload config": {
|
||||
"mango: failed to reload config": "mango: טעינת ההגדרות מחדש נכשלה"
|
||||
"mango: failed to reload config": ""
|
||||
},
|
||||
"mangowc Discord Server": {
|
||||
"mangowc Discord Server": "שרת הDiscord של mangowc"
|
||||
|
||||
@@ -81,7 +81,7 @@
|
||||
"%1 online": "%1 online"
|
||||
},
|
||||
"%1 tasks": {
|
||||
"%1 tasks": "%1 feladat"
|
||||
"%1 tasks": ""
|
||||
},
|
||||
"%1 update": {
|
||||
"%1 update": "%1 frissítés"
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 nap"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 eszköz csatlakoztatva"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 óra 30 perc"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 perc"
|
||||
},
|
||||
@@ -159,10 +153,7 @@
|
||||
"1 second": "1 másodperc"
|
||||
},
|
||||
"1 task": {
|
||||
"1 task": "1 feladat"
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
"1 task": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 perc"
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 perc"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 perc"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 perc"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 perc"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 másodperc"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 perc"
|
||||
},
|
||||
@@ -459,7 +441,7 @@
|
||||
"Add a custom prefix to all application launches. This can be used for things like 'uwsm-app', 'systemd-run', or other command wrappers.": "Adj meg egy egyéni előtagot minden alkalmazás indításához. Ez használható például „uwsm-app”, „systemd-run” vagy más parancscsomagolókhoz."
|
||||
},
|
||||
"Add a task...": {
|
||||
"Add a task...": "Feladat hozzáadása…"
|
||||
"Add a task...": ""
|
||||
},
|
||||
"Add and configure widgets that appear on your desktop": {
|
||||
"Add and configure widgets that appear on your desktop": "Asztali widgetek hozzáadása és beállítása"
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Hozzáadás cím alapján"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": "Egyezés hozzáadása"
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "Az új felhasználó hozzáadása a(z) %1 csoporthoz, hogy futtathassa a dms greeter sync --profile parancsot."
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "Engedélyezés"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Kattintások átengedése a widgeten"
|
||||
},
|
||||
@@ -540,7 +513,7 @@
|
||||
"Already on that session": "Már ebben a munkamenetben vagy"
|
||||
},
|
||||
"Also group repeated application icons on the active workspace": {
|
||||
"Also group repeated application icons on the active workspace": "Az ismétlődő alkalmazásikonok csoportosítása az aktív munkaterületen is"
|
||||
"Also group repeated application icons on the active workspace": ""
|
||||
},
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": {
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": "Alt+←/Backspace: Vissza • F1/I: Fájlinformáció • F10: Súgó • Esc: Bezárás"
|
||||
@@ -585,7 +558,7 @@
|
||||
"Analyzing configuration...": "Konfiguráció elemzése…"
|
||||
},
|
||||
"Anchor": {
|
||||
"Anchor": "Horgony"
|
||||
"Anchor": ""
|
||||
},
|
||||
"Animation Duration": {
|
||||
"Animation Duration": "Animáció időtartama"
|
||||
@@ -612,7 +585,7 @@
|
||||
"App ID": "Alkalmazásazonosító"
|
||||
},
|
||||
"App ID (e.g. firefox)": {
|
||||
"App ID (e.g. firefox)": "Alkalmazás-azonosító (pl. firefox)"
|
||||
"App ID (e.g. firefox)": ""
|
||||
},
|
||||
"App ID Substitutions": {
|
||||
"App ID Substitutions": "Alkalmazásazonosító-helyettesítések"
|
||||
@@ -669,10 +642,10 @@
|
||||
"Apply warm color temperature to reduce eye strain. Use automation settings below to control when it activates.": "Meleg színhőmérséklet alkalmazása a szem megerőltetésének csökkentése érdekében. Az alábbi automatizálási beállítások segítségével szabályozhatod, hogy mikor aktiválódjon."
|
||||
},
|
||||
"Applying authentication changes...": {
|
||||
"Applying authentication changes...": "Hitelesítési módosítások alkalmazása..."
|
||||
"Applying authentication changes...": ""
|
||||
},
|
||||
"Applying auto-login on startup...": {
|
||||
"Applying auto-login on startup...": "Automatikus bejelentkezés alkalmazása indításkor..."
|
||||
"Applying auto-login on startup...": ""
|
||||
},
|
||||
"Apps": {
|
||||
"Apps": "Alkalmazások"
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "Legalább egy kimenetnek engedélyezve kell maradnia"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "Csatlakozás"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Automatikus (széles)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Automatikus helymeghatározás"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Automatikus felugró ablak rések"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "Az automatikus mód be van kapcsolva. A kézi profilválasztás le van tiltva."
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Automatikus törlés"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": "Automatikus bejelentkezés indításkor"
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Automatikus mentés…"
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "A képernyő automatikus zárolása, amikor a rendszer felfüggesztésre készül"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Automatizálás"
|
||||
},
|
||||
@@ -987,17 +942,14 @@
|
||||
"Balanced palette with focused accents (default).": "Kiegyensúlyozott paletta fókuszált kiemelésekkel (alapértelmezett)."
|
||||
},
|
||||
"Bar": {
|
||||
"Bar": "Sáv"
|
||||
"Bar": ""
|
||||
},
|
||||
"Bar %1": {
|
||||
"Bar %1": "%1. sáv"
|
||||
"Bar %1": ""
|
||||
},
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Sáv konfiguráció"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Sáv árnyékai"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "A sávok, felugró ablakok, modális ablakok és értesítések mögötti háttér elmosása. Kompozitor támogatást és beállítást igényel."
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Háttérkép elmosása, ha a niri-áttekintés nyitva van"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Szövegtörzs"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "Félkövér"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "Naptár"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Kamera"
|
||||
},
|
||||
@@ -1338,7 +1281,7 @@
|
||||
"Checking for updates...": "Frissítések keresése…"
|
||||
},
|
||||
"Checking whether sudo authentication is needed...": {
|
||||
"Checking whether sudo authentication is needed...": "Sudo-hitelesítés szükségességének ellenőrzése..."
|
||||
"Checking whether sudo authentication is needed...": ""
|
||||
},
|
||||
"Checking...": {
|
||||
"Checking...": "Ellenőrzés…"
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": "Válaszd ki, hogy asztali alkalmazást vagy parancsot indítasz"
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Mely kijelzők mutassák ezt a widgetet"
|
||||
},
|
||||
@@ -1710,7 +1650,7 @@
|
||||
"Connecting to Device": "Csatlakozás az eszközhöz"
|
||||
},
|
||||
"Connecting to clipboard service...": {
|
||||
"Connecting to clipboard service...": "Kapcsolódás a vágólap-szolgáltatáshoz..."
|
||||
"Connecting to clipboard service...": ""
|
||||
},
|
||||
"Connecting...": {
|
||||
"Connecting...": "Csatlakozás…"
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Az összes felugró ablak, kizárólagos párbeszédablak és tartalomréteg átlátszósága"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "Szabályozza az elmosódott előtér-kártyák, tabletták és értesítési kártyák körüli körvonalakat"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "Az árnyékok alap elmosási sugara és eltolása"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "Szabályozza a protokoll-elmosott ablakok külső szélét"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Kritikus prioritás"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab: Lapváltás • Ctrl+S: Rögzítés/Feloldás • Shift+Del: Összes törlése • Esc: Bezárás"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "A DankMaterialShell használatra kész"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "Alapértelmezett indító gyorsbillentyű"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": "Alapértelmezetten megnyitja"
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Eszköz csatlakozások"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Eszköznevek frissítve"
|
||||
},
|
||||
@@ -2340,7 +2238,7 @@
|
||||
"Disabling WiFi...": "Wi-Fi kikapcsolása…"
|
||||
},
|
||||
"Disabling auto-login on startup...": {
|
||||
"Disabling auto-login on startup...": "Automatikus bejelentkezés letiltása indításkor..."
|
||||
"Disabling auto-login on startup...": ""
|
||||
},
|
||||
"Disc": {
|
||||
"Disc": "Lemez"
|
||||
@@ -2406,7 +2304,7 @@
|
||||
"Display all priorities over fullscreen apps": "Minden prioritás megjelenítése a teljes képernyős alkalmazások felett"
|
||||
},
|
||||
"Display and switch MangoWC layouts": {
|
||||
"Display and switch MangoWC layouts": "MangoWC elrendezések megjelenítése és váltása"
|
||||
"Display and switch MangoWC layouts": ""
|
||||
},
|
||||
"Display application icons in workspace indicators": {
|
||||
"Display application icons in workspace indicators": "Alkalmazás ikonok megjelenítése a munkaterület-jelzőkben"
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dokk és indító"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Dokk átlátszóság"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Dokk láthatósága"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "Dokk margója, átlátszósága és szegélye"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "A szél, ahonnan az indító beúszik"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "Alkalmazás szerkesztése"
|
||||
},
|
||||
@@ -2591,11 +2480,8 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "Vágólap szövegének szerkesztése"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": "Módosítások szerkesztése ezen: %1"
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
"Education": {
|
||||
"Education": "Oktatás"
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Vége"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Nagyítás rámutatáskor"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "15 percenként"
|
||||
},
|
||||
@@ -3111,7 +2991,7 @@
|
||||
"Failed to write autostart entry": "Nem sikerült írni az automatikus indítási bejegyzést"
|
||||
},
|
||||
"Failed to write outputs config.": {
|
||||
"Failed to write outputs config.": "Nem sikerült a kimeneti konfiguráció írása."
|
||||
"Failed to write outputs config.": ""
|
||||
},
|
||||
"Failed to write temp file for validation": {
|
||||
"Failed to write temp file for validation": "Nem sikerült írni az ideiglenes fájlt az ellenőrzéshez"
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "Fájlkezelő"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "A kuka megnyitásához használt fájlkezelő. Válaszd az „egyéni” lehetőséget saját parancs megadásához."
|
||||
},
|
||||
@@ -3237,19 +3114,19 @@
|
||||
"Float": "Lebegő"
|
||||
},
|
||||
"Float Anchor": {
|
||||
"Float Anchor": "Lebegő horgony"
|
||||
"Float Anchor": ""
|
||||
},
|
||||
"Float X": {
|
||||
"Float X": "Lebegő X"
|
||||
"Float X": ""
|
||||
},
|
||||
"Float Y": {
|
||||
"Float Y": "Lebegő Y"
|
||||
"Float Y": ""
|
||||
},
|
||||
"Floating": {
|
||||
"Floating": "Lebegő"
|
||||
},
|
||||
"Floating Position": {
|
||||
"Floating Position": "Lebegő pozíció"
|
||||
"Floating Position": ""
|
||||
},
|
||||
"Fluent": {
|
||||
"Fluent": "Fluent"
|
||||
@@ -3582,7 +3459,7 @@
|
||||
"Group": "Csoport"
|
||||
},
|
||||
"Group Active Workspace": {
|
||||
"Group Active Workspace": "Aktív munkaterület csoportosítása"
|
||||
"Group Active Workspace": ""
|
||||
},
|
||||
"Group Workspace Apps": {
|
||||
"Group Workspace Apps": "Munkaterület-alkalmazások csoportosítása"
|
||||
@@ -3945,7 +3822,7 @@
|
||||
"Inhibitable": "Gátolható"
|
||||
},
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": {
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": "Lebegő ablakok kezdeti pozíciója. Állítsa be az X és Y értéket is; a horgony határozza meg, hogy melyik sarokhoz/élhez képest jelenjenek meg."
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": ""
|
||||
},
|
||||
"Initialised": {
|
||||
"Initialised": "Inicializálva"
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "Helyezd be a biztonsági kulcsodat…"
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Telepítés"
|
||||
},
|
||||
@@ -4053,7 +3927,7 @@
|
||||
"Invert on mode change": "Invertálás módváltáskor"
|
||||
},
|
||||
"Invert touchpad scroll direction": {
|
||||
"Invert touchpad scroll direction": "Érintőtábla görgetési irányának megfordítása"
|
||||
"Invert touchpad scroll direction": ""
|
||||
},
|
||||
"Iris Bloom": {
|
||||
"Iris Bloom": "Íriszvirágzás"
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Változtatások megtartása"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "Gépelj tovább"
|
||||
},
|
||||
@@ -4386,10 +4254,10 @@
|
||||
"Manages files and directories": "Fájlok és könyvtárak kezelése"
|
||||
},
|
||||
"Mango Options": {
|
||||
"Mango Options": "Mango beállítások"
|
||||
"Mango Options": ""
|
||||
},
|
||||
"Mango service not available": {
|
||||
"Mango service not available": "A Mango szolgáltatás nem érhető el"
|
||||
"Mango service not available": ""
|
||||
},
|
||||
"MangoWC Layout Overrides": {
|
||||
"MangoWC Layout Overrides": "MangoWC elrendezés felülbírálások"
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Manuális rés mérete"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Manuális megjelenítés/elrejtés"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "Max. futó alk. (0 = korlátlan)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Maximális hangerő"
|
||||
},
|
||||
@@ -4779,7 +4641,7 @@
|
||||
"Native: platform renderer (FreeType).": "Natív: platformmegjelenítő (FreeType)."
|
||||
},
|
||||
"Natural Touchpad Scrolling": {
|
||||
"Natural Touchpad Scrolling": "Természetes érintőtábla-görgetés"
|
||||
"Natural Touchpad Scrolling": ""
|
||||
},
|
||||
"Navigate": {
|
||||
"Navigate": "Navigáció"
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Új csoportnév…"
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Nincs elérhető fényerő eszköz"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Nincs változás"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Nem találhatók legutóbbi vágólapbejegyzések"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "Nincs találat"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Nincsenek ablakszabályok beállítva"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": "Zaj"
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Jegyzettömb-betűbeállítások"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Jegyzettömb oldalsáv"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Semmi"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "Nyitott keret"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Nyisd meg a KDE Connectet a telefonodon"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Beillesztés"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Egy videófájl vagy videókat tartalmazó mappa elérési útja"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "A Polkit-integráció ki van kapcsolva. A felhasználókezeléshez a Polkit szükséges a jogosultságok emeléséhez."
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "Felugró ablak árnyékok"
|
||||
},
|
||||
@@ -6114,7 +5949,7 @@
|
||||
"Refresh Weather": "Időjárás frissítése"
|
||||
},
|
||||
"Refreshing...": {
|
||||
"Refreshing...": "Frissítés…"
|
||||
"Refreshing...": ""
|
||||
},
|
||||
"Regex": {
|
||||
"Regex": "Regex"
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Felengedés"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Bővítmény újratöltése"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Utolsó felhasználó megjegyzése"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Eltávolítás"
|
||||
},
|
||||
@@ -6246,7 +6075,7 @@
|
||||
"Requires DMS server with sysupdate capability": "DMS-szerver szükséges sysupdate-képességgel"
|
||||
},
|
||||
"Requires MangoWC compositor": {
|
||||
"Requires MangoWC compositor": "MangoWC kompozitor szükséges"
|
||||
"Requires MangoWC compositor": ""
|
||||
},
|
||||
"Requires a newer version of Quickshell": {
|
||||
"Requires a newer version of Quickshell": "A Quickshell újabb verziója szükséges"
|
||||
@@ -6279,10 +6108,10 @@
|
||||
"Resize Widget": "Widget méretezése"
|
||||
},
|
||||
"Resize on Border": {
|
||||
"Resize on Border": "Átméretezés a szegélynél"
|
||||
"Resize on Border": ""
|
||||
},
|
||||
"Resize windows by dragging their edges with the mouse": {
|
||||
"Resize windows by dragging their edges with the mouse": "Ablakok átméretezése a szegélyük egérrel történő húzásával"
|
||||
"Resize windows by dragging their edges with the mouse": ""
|
||||
},
|
||||
"Resolution & Refresh": {
|
||||
"Resolution & Refresh": "Felbontás és frissítés"
|
||||
@@ -6393,7 +6222,7 @@
|
||||
"Running Apps Settings": "Futó alkalmazások beállításai"
|
||||
},
|
||||
"Running greeter sync...": {
|
||||
"Running greeter sync...": "Üdvözlőképernyő-szinkronizáció futtatása..."
|
||||
"Running greeter sync...": ""
|
||||
},
|
||||
"Running in terminal": {
|
||||
"Running in terminal": "Futtatás terminálban"
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Mentés…"
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Skála"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Értesítési szabályok beállítása"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "Beállítás"
|
||||
},
|
||||
@@ -7013,11 +6833,8 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Munkaterület-alkalmazások megjelenítése"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": "Mind a 9 címke megjelenítése a csak foglalt címkék helyett"
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
"Show an outline ring around the focused workspace indicator": {
|
||||
"Show an outline ring around the focused workspace indicator": "Körvonal megjelenítése a fókuszált munkaterület-jelző körül"
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "Értesítések némítása"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Méret"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": "Kihagyja a rendszerindítás után az üdvözlőképernyő jelszavát a kijelentkezésig. A zárolási képernyő feloldása változatlan marad. A szinkronizálás utáni következő újraindításkor lép életbe."
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Kicsi"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Összegzés"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Napkelte"
|
||||
},
|
||||
@@ -7455,7 +7263,7 @@
|
||||
"Tab/Shift+Tab: Nav • ←→↑↓: Grid Nav • Enter/Space: Select": "Tab/Shift+Tab: Nav • ←→↑↓: Rács Nav • Enter/Szóköz: Kiválasztás"
|
||||
},
|
||||
"Tags": {
|
||||
"Tags": "Címkék"
|
||||
"Tags": ""
|
||||
},
|
||||
"Tags: %1": {
|
||||
"Tags: %1": "Címkék: %1"
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Időtúllépés"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Időtúllépés a kritikus prioritású értesítésekhez"
|
||||
},
|
||||
@@ -7686,10 +7491,7 @@
|
||||
"Title": "Cím"
|
||||
},
|
||||
"Title (optional)": {
|
||||
"Title (optional)": "Cím (nem kötelező)"
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Cím reguláris kifejezése (opcionális)"
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Rács elrendezés használata"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "IP-cím használata"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "A „spotlight-bar” IPC-műveletet használja, és mindig a minimális sávot nyitja meg."
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "A Beállítások → Személyre szabás menüpontban megadott globális rögzített szélességű betűtípus használata"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "A Gammavezérlés megosztott beállításainak használata"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Láthatóság"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Vizuális effektusok"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Widgetkezelés"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Widget körvonal"
|
||||
},
|
||||
@@ -8418,7 +8205,7 @@
|
||||
"Widgets": "Widgetek"
|
||||
},
|
||||
"Widgets & Notifications": {
|
||||
"Widgets & Notifications": "Widgetek és értesítések"
|
||||
"Widgets & Notifications": ""
|
||||
},
|
||||
"Widgets, layout, style": {
|
||||
"Widgets, layout, style": "Widgetek, elrendezés, stílus"
|
||||
@@ -8433,7 +8220,7 @@
|
||||
"Width of the widget outline in pixels": "A widget körvonalának szélessége képpontban"
|
||||
},
|
||||
"Width of window border": {
|
||||
"Width of window border": "Ablakszegély szélessége"
|
||||
"Width of window border": ""
|
||||
},
|
||||
"Width of window border and focus ring": {
|
||||
"Width of window border and focus ring": "Ablakszegély és fókuszgyűrű szélessége"
|
||||
@@ -8475,7 +8262,7 @@
|
||||
"Wipe": "Törlés"
|
||||
},
|
||||
"Working...": {
|
||||
"Working...": "Dolgozom..."
|
||||
"Working...": ""
|
||||
},
|
||||
"Workspace": {
|
||||
"Workspace": "Munkaterület"
|
||||
@@ -8511,7 +8298,7 @@
|
||||
"Write:": "Írás:"
|
||||
},
|
||||
"X": {
|
||||
"X": "X"
|
||||
"X": ""
|
||||
},
|
||||
"X Axis": {
|
||||
"X Axis": "X tengely"
|
||||
@@ -8526,7 +8313,7 @@
|
||||
"Xray blurs only the wallpaper (efficient) and is the default when Blur is on. Set Xray to Off for regular full blur of everything beneath the window (more expensive).": "Az X-Ray csak a háttérképet mossa el (hatékony), és ez az alapértelmezett, ha az Elmosás be van kapcsolva. Állítsd az X-Ray-t Ki állásba az ablak alatti összes elem normál, teljes elmosásához (erőforrás-igényesebb)."
|
||||
},
|
||||
"Y": {
|
||||
"Y": "Y"
|
||||
"Y": ""
|
||||
},
|
||||
"Y Axis": {
|
||||
"Y Axis": "Y tengely"
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "kiemelt"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "utoljára látva: %1"
|
||||
},
|
||||
@@ -8655,10 +8439,10 @@
|
||||
"loginctl not available - lock integration requires DMS socket connection": "A loginctl nem érhető el – a zárolás integrációhoz DMS-socketkapcsolat szükséges"
|
||||
},
|
||||
"mango: config reloaded": {
|
||||
"mango: config reloaded": "mango: konfiguráció újratöltve"
|
||||
"mango: config reloaded": ""
|
||||
},
|
||||
"mango: failed to reload config": {
|
||||
"mango: failed to reload config": "mango: nem sikerült újratölteni a konfigurációt"
|
||||
"mango: failed to reload config": ""
|
||||
},
|
||||
"mangowc Discord Server": {
|
||||
"mangowc Discord Server": "mangowc Discord szerver"
|
||||
|
||||
@@ -81,7 +81,7 @@
|
||||
"%1 online": "%1 online"
|
||||
},
|
||||
"%1 tasks": {
|
||||
"%1 tasks": "%1 attività"
|
||||
"%1 tasks": ""
|
||||
},
|
||||
"%1 update": {
|
||||
"%1 update": "%1 aggiornamento"
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 giorno"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 dispositivo connesso"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 ora 30 minuti"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 minuto"
|
||||
},
|
||||
@@ -159,10 +153,7 @@
|
||||
"1 second": "1 secondo"
|
||||
},
|
||||
"1 task": {
|
||||
"1 task": "1 attività"
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
"1 task": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 minuti"
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 minuti"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 minuti"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 minuti"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 minuti"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 secondi"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 minuti"
|
||||
},
|
||||
@@ -459,7 +441,7 @@
|
||||
"Add a custom prefix to all application launches. This can be used for things like 'uwsm-app', 'systemd-run', or other command wrappers.": "Aggiungi un prefisso personalizzato all'avvio di tutte le applicazioni. Può essere utilizzato per strumenti come \"uwsm-app\", \"systemd-run\" o altri wrapper di comandi."
|
||||
},
|
||||
"Add a task...": {
|
||||
"Add a task...": "Aggiungi un'attività..."
|
||||
"Add a task...": ""
|
||||
},
|
||||
"Add and configure widgets that appear on your desktop": {
|
||||
"Add and configure widgets that appear on your desktop": "Aggiungi e configura widget che compaiono sul tuo desktop"
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Aggiungi tramite Indirizzo"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": "Aggiungi Corrispondenza"
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "Aggiungi il nuovo utente al gruppo %1 in modo che possa eseguire il comando dms greeter sync --profile."
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "Consenti"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Consenti clic attraverso il widget"
|
||||
},
|
||||
@@ -540,7 +513,7 @@
|
||||
"Already on that session": "Già in quella sessione"
|
||||
},
|
||||
"Also group repeated application icons on the active workspace": {
|
||||
"Also group repeated application icons on the active workspace": "Raggruppa anche le icone ripetute delle applicazioni nello spazio di lavoro attivo"
|
||||
"Also group repeated application icons on the active workspace": ""
|
||||
},
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": {
|
||||
"Alt+←/Backspace: Back • F1/I: File Info • F10: Help • Esc: Close": "Alt+←/Backspace: Indietro • F1/I: Info File • F10: Aiuto • Esc: Chiudi"
|
||||
@@ -585,7 +558,7 @@
|
||||
"Analyzing configuration...": "Analisi configurazione in corso..."
|
||||
},
|
||||
"Anchor": {
|
||||
"Anchor": "Ancora"
|
||||
"Anchor": ""
|
||||
},
|
||||
"Animation Duration": {
|
||||
"Animation Duration": "Durata Animazione"
|
||||
@@ -612,7 +585,7 @@
|
||||
"App ID": "ID Applicazione"
|
||||
},
|
||||
"App ID (e.g. firefox)": {
|
||||
"App ID (e.g. firefox)": "ID App (es. firefox)"
|
||||
"App ID (e.g. firefox)": ""
|
||||
},
|
||||
"App ID Substitutions": {
|
||||
"App ID Substitutions": "Sostituzioni App ID"
|
||||
@@ -669,10 +642,10 @@
|
||||
"Apply warm color temperature to reduce eye strain. Use automation settings below to control when it activates.": "Applica una temperatura colore più calda per ridurre l'affaticamento visivo. Usa le impostazioni di automazione qui sotto per controllare quando attivarla."
|
||||
},
|
||||
"Applying authentication changes...": {
|
||||
"Applying authentication changes...": "Applicazione modifiche di autenticazione..."
|
||||
"Applying authentication changes...": ""
|
||||
},
|
||||
"Applying auto-login on startup...": {
|
||||
"Applying auto-login on startup...": "Applicazione accesso automatico all'avvio..."
|
||||
"Applying auto-login on startup...": ""
|
||||
},
|
||||
"Apps": {
|
||||
"Apps": "App"
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "Almeno un output deve rimanere abilitato"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "Aggancia"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Automatico (Ampio)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Posizione Automatica"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Spaziature Popup Automatiche"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "Modalità automatica attiva. Selezione dei profili manuale disabilitata."
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Cancellazione Automatica Dopo"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": "Accesso Automatico all'Avvio"
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Salvataggio in corso..."
|
||||
},
|
||||
@@ -908,14 +866,11 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Blocca automaticamente lo schermo quando il sistema si prepara alla sospensione"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Automazione"
|
||||
},
|
||||
"Autostart Apps": {
|
||||
"Autostart Apps": "App in Avvio Automatico"
|
||||
"Autostart Apps": "Applicazioni in Avvio Automatico"
|
||||
},
|
||||
"Autostart Entries": {
|
||||
"Autostart Entries": "Voci in Avvio Automatico"
|
||||
@@ -987,17 +942,14 @@
|
||||
"Balanced palette with focused accents (default).": "Tavolozza bilanciata con accenti focalizzati (predefinito)."
|
||||
},
|
||||
"Bar": {
|
||||
"Bar": "Barra"
|
||||
"Bar": ""
|
||||
},
|
||||
"Bar %1": {
|
||||
"Bar %1": "Barra %1"
|
||||
"Bar %1": ""
|
||||
},
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Configurazioni Barra"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Ombre della Barra"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "Sfoca lo sfondo dietro barre, popup, finestre modali e notifiche. Richiede supporto e configurazione del compositore."
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Sfoca lo sfondo quando la panoramica di niri è aperta"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Corpo"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "Grassetto"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "Calendario"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Fotocamera"
|
||||
},
|
||||
@@ -1338,7 +1281,7 @@
|
||||
"Checking for updates...": "Controllo aggiornamenti..."
|
||||
},
|
||||
"Checking whether sudo authentication is needed...": {
|
||||
"Checking whether sudo authentication is needed...": "Verifica della necessità di autenticazione sudo..."
|
||||
"Checking whether sudo authentication is needed...": ""
|
||||
},
|
||||
"Checking...": {
|
||||
"Checking...": "Verifica in corso..."
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": "Scegli se avviare un'applicazione desktop o un comando"
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Scegli su quali schermi mostrare questo widget"
|
||||
},
|
||||
@@ -1710,7 +1650,7 @@
|
||||
"Connecting to Device": "Connessione al Dispositivo"
|
||||
},
|
||||
"Connecting to clipboard service...": {
|
||||
"Connecting to clipboard service...": "Connessione al servizio degli appunti..."
|
||||
"Connecting to clipboard service...": ""
|
||||
},
|
||||
"Connecting...": {
|
||||
"Connecting...": "Connessione in corso..."
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Controlla l'opacità di tutti i popup, le finestre modali e i loro livelli di contenuto"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "Determina i contorni attorno alle schede in primo piano sfocate, alle pillole e alle schede di notifica"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "Controlla il raggio di sfocatura base e l'offset delle ombre"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "Determina il bordo esterno delle finestre con sfocatura da protocollo"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Priorità Critica"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab: Cambia Tab • Ctrl+S: Aggiungi/Rimuovi • Shift+Del: Cancella Tutto • Esc: Chiudi"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell è pronta per l'uso"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "Collegamento Predefinito del Launcher"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": "Aperture Predefinite"
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Connessioni del dispositivo"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Nomi dei dispositivi aggiornati"
|
||||
},
|
||||
@@ -2340,7 +2238,7 @@
|
||||
"Disabling WiFi...": "Disattivazione Wi-Fi..."
|
||||
},
|
||||
"Disabling auto-login on startup...": {
|
||||
"Disabling auto-login on startup...": "Disabilitazione accesso automatico all'avvio..."
|
||||
"Disabling auto-login on startup...": ""
|
||||
},
|
||||
"Disc": {
|
||||
"Disc": "Disco"
|
||||
@@ -2406,7 +2304,7 @@
|
||||
"Display all priorities over fullscreen apps": "Mostra priorità sopra app a schermo intero"
|
||||
},
|
||||
"Display and switch MangoWC layouts": {
|
||||
"Display and switch MangoWC layouts": "Mostra e cambia i layout di MangoWC"
|
||||
"Display and switch MangoWC layouts": ""
|
||||
},
|
||||
"Display application icons in workspace indicators": {
|
||||
"Display application icons in workspace indicators": "Mostra icone applicazioni negli indicatori degli spazi di lavoro"
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock e Launcher"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Trasparenza Dock"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Visibilità Dock"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "Margine, trasparenza e bordo del dock"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "Lato da cui scorre il launcher"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "Modifica App"
|
||||
},
|
||||
@@ -2591,11 +2480,8 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "Modifica il testo degli appunti"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": "Modifiche in corso su %1"
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
"Education": {
|
||||
"Education": "Istruzione"
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Fine"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Ingrandisci al passaggio del mouse"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "Ogni 15 minuti"
|
||||
},
|
||||
@@ -3111,7 +2991,7 @@
|
||||
"Failed to write autostart entry": "Impossibile scrivere la voce di avvio automatico"
|
||||
},
|
||||
"Failed to write outputs config.": {
|
||||
"Failed to write outputs config.": "Impossibile scrivere la configurazione degli output."
|
||||
"Failed to write outputs config.": ""
|
||||
},
|
||||
"Failed to write temp file for validation": {
|
||||
"Failed to write temp file for validation": "Impossibile scrivere il file temporaneo per la validazione"
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "Gestore File"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "Il gestore dei file utilizzato per aprire il cestino. Seleziona \"personalizzato\" per inserire il tuo comando."
|
||||
},
|
||||
@@ -3237,19 +3114,19 @@
|
||||
"Float": "Fluttuante"
|
||||
},
|
||||
"Float Anchor": {
|
||||
"Float Anchor": "Ancora Fluttuante"
|
||||
"Float Anchor": ""
|
||||
},
|
||||
"Float X": {
|
||||
"Float X": "X Fluttuante"
|
||||
"Float X": ""
|
||||
},
|
||||
"Float Y": {
|
||||
"Float Y": "Y Fluttuante"
|
||||
"Float Y": ""
|
||||
},
|
||||
"Floating": {
|
||||
"Floating": "Fluttuante"
|
||||
},
|
||||
"Floating Position": {
|
||||
"Floating Position": "Posizione Fluttuante"
|
||||
"Floating Position": ""
|
||||
},
|
||||
"Fluent": {
|
||||
"Fluent": "Fluente"
|
||||
@@ -3582,7 +3459,7 @@
|
||||
"Group": "Gruppo"
|
||||
},
|
||||
"Group Active Workspace": {
|
||||
"Group Active Workspace": "Raggruppa Spazio di Lavoro Attivo"
|
||||
"Group Active Workspace": ""
|
||||
},
|
||||
"Group Workspace Apps": {
|
||||
"Group Workspace Apps": "Raggruppa App per Spazio di Lavoro"
|
||||
@@ -3717,7 +3594,7 @@
|
||||
"Hide the bar when the pointer leaves even if a popout is still open": "Nascondi la barra quando il puntatore esce, anche se una finestra a comparsa è ancora aperta."
|
||||
},
|
||||
"High": {
|
||||
"High": "Alta"
|
||||
"High": "Alto"
|
||||
},
|
||||
"High-fidelity palette that preserves source hues.": {
|
||||
"High-fidelity palette that preserves source hues.": "Tavolozza ad alta fedeltà che preserva le tonalità della sorgente."
|
||||
@@ -3945,7 +3822,7 @@
|
||||
"Inhibitable": "Inibibile"
|
||||
},
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": {
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": "Posizione iniziale per le finestre fluttuanti. Imposta sia X che Y; l'ancora controlla a quale angolo/bordo sono relative."
|
||||
"Initial position for floating windows. Set both X and Y; anchor controls which corner/edge they're relative to.": ""
|
||||
},
|
||||
"Initialised": {
|
||||
"Initialised": "Inizializzato"
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "Inserisci la tua chiave di sicurezza..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Installa"
|
||||
},
|
||||
@@ -4053,7 +3927,7 @@
|
||||
"Invert on mode change": "Inverti al cambio di modalità"
|
||||
},
|
||||
"Invert touchpad scroll direction": {
|
||||
"Invert touchpad scroll direction": "Inverti direzione di scorrimento del touchpad"
|
||||
"Invert touchpad scroll direction": ""
|
||||
},
|
||||
"Iris Bloom": {
|
||||
"Iris Bloom": "Effetto Iride"
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Conserva Modifiche"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "Continua a digitare"
|
||||
},
|
||||
@@ -4341,7 +4209,7 @@
|
||||
"Longitude": "Longitudine"
|
||||
},
|
||||
"Low": {
|
||||
"Low": "Bassa"
|
||||
"Low": "Basso"
|
||||
},
|
||||
"Low Priority": {
|
||||
"Low Priority": "Bassa Priorità"
|
||||
@@ -4386,10 +4254,10 @@
|
||||
"Manages files and directories": "Gestisce file e directory"
|
||||
},
|
||||
"Mango Options": {
|
||||
"Mango Options": "Opzioni Mango"
|
||||
"Mango Options": ""
|
||||
},
|
||||
"Mango service not available": {
|
||||
"Mango service not available": "Servizio Mango non disponibile"
|
||||
"Mango service not available": ""
|
||||
},
|
||||
"MangoWC Layout Overrides": {
|
||||
"MangoWC Layout Overrides": "Sovrascritture Layout MangoWC"
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Dimensione Manuale Spaziatura"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Mostra/Nascondi Manuale"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "App in Esecuzione Massime (0 = Illimitate)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Volume Massimo"
|
||||
},
|
||||
@@ -4779,7 +4641,7 @@
|
||||
"Native: platform renderer (FreeType).": "Native: renderer di piattaforma (FreeType)."
|
||||
},
|
||||
"Natural Touchpad Scrolling": {
|
||||
"Natural Touchpad Scrolling": "Scorrimento Naturale del Touchpad"
|
||||
"Natural Touchpad Scrolling": ""
|
||||
},
|
||||
"Navigate": {
|
||||
"Navigate": "Naviga"
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Nome del nuovo gruppo..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Nessun dispositivo di luminosità disponibile"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Nessun cambiamento"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Nessuna voce recente negli appunti"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "Nessun risultato"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Nessuna regola finestra configurata"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": "Rumore"
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Impostazioni Font Blocco Note"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Blocco Note a Comparsa"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Niente"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "Apri Cornice"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Apri KDE Connect sul tuo telefono"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Incolla"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Percorso di un file video o di una cartella contenente video"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "L'integrazione con Polkit è disabilitata. La gestione degli utenti richiede che Polkit elevi i privilegi."
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "Ombre dei Popup"
|
||||
},
|
||||
@@ -6114,7 +5949,7 @@
|
||||
"Refresh Weather": "Aggiorna Meteo"
|
||||
},
|
||||
"Refreshing...": {
|
||||
"Refreshing...": "Aggiornamento..."
|
||||
"Refreshing...": ""
|
||||
},
|
||||
"Regex": {
|
||||
"Regex": "Regex"
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Rilascio"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Ricarica Plugin"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Ricorda l'ultimo utente"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Rimuovi"
|
||||
},
|
||||
@@ -6246,7 +6075,7 @@
|
||||
"Requires DMS server with sysupdate capability": "È necessario un server DMS dotato della funzionalità sysupdate"
|
||||
},
|
||||
"Requires MangoWC compositor": {
|
||||
"Requires MangoWC compositor": "Richiede il compositor MangoWC"
|
||||
"Requires MangoWC compositor": ""
|
||||
},
|
||||
"Requires a newer version of Quickshell": {
|
||||
"Requires a newer version of Quickshell": "Richiede una versione più recente di Quickshell"
|
||||
@@ -6279,10 +6108,10 @@
|
||||
"Resize Widget": "Ridimensiona Widget"
|
||||
},
|
||||
"Resize on Border": {
|
||||
"Resize on Border": "Ridimensiona dal Bordo"
|
||||
"Resize on Border": ""
|
||||
},
|
||||
"Resize windows by dragging their edges with the mouse": {
|
||||
"Resize windows by dragging their edges with the mouse": "Ridimensiona le finestre trascinando i bordi con il mouse"
|
||||
"Resize windows by dragging their edges with the mouse": ""
|
||||
},
|
||||
"Resolution & Refresh": {
|
||||
"Resolution & Refresh": "Risoluzione e Frequenza di Aggiornamento"
|
||||
@@ -6393,7 +6222,7 @@
|
||||
"Running Apps Settings": "Impostazioni App in Esecuzione"
|
||||
},
|
||||
"Running greeter sync...": {
|
||||
"Running greeter sync...": "Esecuzione sincronizzazione greeter..."
|
||||
"Running greeter sync...": ""
|
||||
},
|
||||
"Running in terminal": {
|
||||
"Running in terminal": "In esecuzione nel terminale"
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Salvataggio..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Scala"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Imposta regole di notifica"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "Impostazione"
|
||||
},
|
||||
@@ -7013,11 +6833,8 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Mostra App negli Spazi di Lavoro"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": "Mostra tutti e 9 i tag invece dei soli tag occupati"
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
"Show an outline ring around the focused workspace indicator": {
|
||||
"Show an outline ring around the focused workspace indicator": "Mostra un bordo attorno all’indicatore dello spazio di lavoro attivo"
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "Disattiva le notifiche"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Dimensione"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": "Salta la password del greeter dopo l'avvio fino alla disconnessione. Lo sblocco della schermata di blocco rimane invariato. Ha effetto al prossimo riavvio dopo la sincronizzazione."
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Piccolo"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Riassunto"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Alba"
|
||||
},
|
||||
@@ -7455,7 +7263,7 @@
|
||||
"Tab/Shift+Tab: Nav • ←→↑↓: Grid Nav • Enter/Space: Select": "Tab/Shift+Tab: Nav • ←→↑↓: Nav Griglia • Invio/Spazio: Seleziona"
|
||||
},
|
||||
"Tags": {
|
||||
"Tags": "Tag"
|
||||
"Tags": ""
|
||||
},
|
||||
"Tags: %1": {
|
||||
"Tags: %1": "Tag: %1"
|
||||
@@ -7557,7 +7365,7 @@
|
||||
"Theme color used for the widget outline": "Colore del tema utilizzato per il contorno del widget"
|
||||
},
|
||||
"Theme worker failed (%1)": {
|
||||
"Theme worker failed (%1)": "Lavoratore tema non riuscito (%1)"
|
||||
"Theme worker failed (%1)": "Lavoratore a tema non riuscito (%1)"
|
||||
},
|
||||
"Themes": {
|
||||
"Themes": "Temi"
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Scaduto"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Timeout per le notifiche di priorità critica"
|
||||
},
|
||||
@@ -7686,10 +7491,7 @@
|
||||
"Title": "Titolo"
|
||||
},
|
||||
"Title (optional)": {
|
||||
"Title (optional)": "Titolo (opzionale)"
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Regex titolo (opzionale)"
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Usa Layout a Griglia"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Usa Posizione IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "Utilizza l'azione IPC spotlight-bar e apre sempre la barra minima."
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "Utilizzo del font monospace globale da Impostazioni → Personalizzazione"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Utilizzo delle impostazioni condivise di Gamma Control"
|
||||
},
|
||||
@@ -8241,7 +8034,7 @@
|
||||
"Vertical Tiling": "Tiling Verticale"
|
||||
},
|
||||
"Very High": {
|
||||
"Very High": "Molto Alta"
|
||||
"Very High": "Molto Alto"
|
||||
},
|
||||
"Vibrant": {
|
||||
"Vibrant": "Vivace"
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Visibilità"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Effetti Visivi"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Gestione Widget"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Contorno Widget"
|
||||
},
|
||||
@@ -8418,7 +8205,7 @@
|
||||
"Widgets": "Widget"
|
||||
},
|
||||
"Widgets & Notifications": {
|
||||
"Widgets & Notifications": "Widget e Notifiche"
|
||||
"Widgets & Notifications": ""
|
||||
},
|
||||
"Widgets, layout, style": {
|
||||
"Widgets, layout, style": "Widget, layout, stile"
|
||||
@@ -8433,7 +8220,7 @@
|
||||
"Width of the widget outline in pixels": "Larghezza del contorno del widget in pixel"
|
||||
},
|
||||
"Width of window border": {
|
||||
"Width of window border": "Larghezza del bordo della finestra"
|
||||
"Width of window border": ""
|
||||
},
|
||||
"Width of window border and focus ring": {
|
||||
"Width of window border and focus ring": "Larghezza del bordo e dell'anello di focus"
|
||||
@@ -8475,7 +8262,7 @@
|
||||
"Wipe": "Tendina"
|
||||
},
|
||||
"Working...": {
|
||||
"Working...": "Elaborazione..."
|
||||
"Working...": ""
|
||||
},
|
||||
"Workspace": {
|
||||
"Workspace": "Spazio di Lavoro"
|
||||
@@ -8511,7 +8298,7 @@
|
||||
"Write:": "Scrittura:"
|
||||
},
|
||||
"X": {
|
||||
"X": "X"
|
||||
"X": ""
|
||||
},
|
||||
"X Axis": {
|
||||
"X Axis": "Asse X"
|
||||
@@ -8526,7 +8313,7 @@
|
||||
"Xray blurs only the wallpaper (efficient) and is the default when Blur is on. Set Xray to Off for regular full blur of everything beneath the window (more expensive).": "I Raggi X sfocano solo lo sfondo (efficiente) ed è l'impostazione predefinita quando la Sfocatura è attiva. Imposta Raggi X su Spento per una normale sfocatura completa di tutto ciò che si trova sotto la finestra (più costoso)."
|
||||
},
|
||||
"Y": {
|
||||
"Y": "Y"
|
||||
"Y": ""
|
||||
},
|
||||
"Y Axis": {
|
||||
"Y Axis": "Asse Y"
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "in primo piano"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "visto l'ultima volta %1"
|
||||
},
|
||||
@@ -8655,10 +8439,10 @@
|
||||
"loginctl not available - lock integration requires DMS socket connection": "loginctl non disponibile - integrazione blocco richiede connessione socket DMS"
|
||||
},
|
||||
"mango: config reloaded": {
|
||||
"mango: config reloaded": "mango: configurazione ricaricata"
|
||||
"mango: config reloaded": ""
|
||||
},
|
||||
"mango: failed to reload config": {
|
||||
"mango: failed to reload config": "mango: impossibile ricaricare la configurazione"
|
||||
"mango: failed to reload config": ""
|
||||
},
|
||||
"mangowc Discord Server": {
|
||||
"mangowc Discord Server": "Server Discord di mangowc"
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1日"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1台接続済み"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1時間30分"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1分"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10分"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 分"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15分"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 分"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30分"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45秒"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5分"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "アドレスで追加"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "クリックをウィジェットに透過させる"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "少なくとも1つの出力は有効のままにしておく必要がある"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "添付"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "自動(ワイド)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "自動位置検出"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "自動ポップアップギャップ"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "自動モードがオンになっています。手動プロファイル選択は無効になっています。"
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "自動消去まで"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "自動保存中..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "システムが一時停止の準備中に自動的に画面をロック"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "自動化"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "バーの設定"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "バーの影"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "バー、ポップアウト、モーダル、通知の背後の背景をぼかす。コンポジターのサポートと設定が必要。"
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Niri 概要が開いているときに壁紙をぼかす"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "本文"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "ボールド"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "カレンダー"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "カメラ"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "このウィジェットを表示するディスプレイを選ぶ"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "すべてのポップアウト、モーダル、およびそのコンテンツレイヤーの透明度を制御"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "ぼかした前景カード、ピル型要素、通知カードのアウトラインを調整"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "影の基本ぼかし半径とオフセットを制御"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "プロトコルによるぼかしが適用されたウィンドウの外縁を調整"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "最優先事項"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab: タブ切替 • Ctrl+S: ピン留め/解除 • Shift+Del: すべてクリア • Esc: 閉じる"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell は使用可能です"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "デバイス接続"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "デバイス名を更新しました"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "ドックとランチャー"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "ドックの透明度"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "ドックの表示"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "ドックの余白、透明度、境界線"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "ランチャーのスライドを端から"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "アプリを編集"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "終わり"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "ホバー時に拡大"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "15分ごと"
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "ファイルマネージャー"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "ゴミ箱を開くために使用するファイルマネージャーです。独自のコマンドを入力するには「カスタム」を選択してください。"
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "セキュリティキーを挿入してください..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "インストール"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "変更を保持"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "入力し続けてください"
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "手動ギャップサイズ"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "手動で表示/非表示"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "最大実行中アプリ数(0 = 無制限)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "最大音量"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "新しいグループ名..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "利用可能な明るさデバイスがありません"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "変更なし"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "最近のクリップボードエントリは見つかりませんでした"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "検索結果なし"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "ウィンドウルールは設定されていません"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "メモ帳のフォント設定"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "メモ帳スライドアウト"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "なし"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "オープンフレーム"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "スマートフォンで KDE Connect を開く"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "貼り付け"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "動画ファイル、または動画を含むフォルダーへのパス"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "ポップアウトの影"
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "離す"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "プラグインをリロード"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "最後のユーザーを記憶"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "削除"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "保存しています..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "スケール"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "通知ルールを設定"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "設定"
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "ワークスペースアプリを表示"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "通知をミュート"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "サイズ"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "小"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "概要"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "日の出"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "タイムアウト"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "最優先通知のタイムアウト"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "タイトルの正規表現(任意)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "グリッドレイアウトを使用"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "IP ロケーションの使用"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "設定 → パーソナライズからグローバル等幅フォントを使用する"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Gamma Control の共有設定を使用中"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "視界"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "視覚効果"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "ウィジェット管理"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "ウィジェットのアウトライン"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "おすすめ"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "最後に確認されたのは 1%"
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 dag"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 apparaat verbonden"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 uur 30 minuten"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 minuut"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 minuten"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 min"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 minuten"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 min"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 minuten"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 seconden"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 minuten"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Toevoegen op adres"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Klikken door de widget heen laten gaan"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "Er moet ten minste één beeldscherm ingeschakeld blijven"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "Koppelen"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Auto (Breed)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Automatische locatie"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Automatische tussenruimte popups"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "Automatische modus staat aan. Handmatige profielselectie is uitgeschakeld."
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Automatisch wissen na"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Automatisch opslaan..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Het scherm automatisch vergrendelen wanneer het systeem in slaapstand gaat"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Automatisering"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Balkconfiguraties"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Balkschaduwen"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "Vervaag de achtergrond achter balken, pop-ups, modale vensters en meldingen. Vereist ondersteuning van de compositor en configuratie."
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Achtergrond vervagen wanneer niri-overzicht open is"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Inhoud"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "Vet"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "Agenda"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Camera"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Kies welke beeldschermen deze widget tonen"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Regelt dekking van alle pop-outs, modale vensters en hun inhoudslagen"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "Bepaalt omlijningen rond vervaagde voorgrondkaarten, pillen en meldingskaarten"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "Bepaalt de basisvervagingsstraal en verschuiving van schaduwen"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "Bepaalt de buitenrand van door het protocol vervaagde vensters"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Kritieke prioriteit"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab: Wissel tabblad • Ctrl+S: Vastzetten/losmaken • Shift+Del: Alles wissen • Esc: Sluiten"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell is klaar voor gebruik"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Apparaatverbindingen"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Apparaatnamen bijgewerkt"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock & Starter"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Dock-transparantie"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Zichtbaarheid dock"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "Marge, transparantie en rand van het dock"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "Rand waaruit de launcher schuift"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "App bewerken"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Einde"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Vergroten bij aanwijzen"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "Elke 15 minuten"
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "Bestandsbeheer"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "Bestandsbeheerder die wordt gebruikt om de prullenbak te openen. Kies \"aangepast\" om je eigen opdracht in te voeren."
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "Plaats uw beveiligingssleutel..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Installeren"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Wijzigingen behouden"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "Blijf typen"
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Handmatige grootte tussenruimte"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Handmatig tonen/verbergen"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "Max. actieve apps (0 = onbeperkt)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Max. volume"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Nieuwe groepsnaam..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Geen helderheidsapparaten beschikbaar"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Geen wijzigingen"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Geen recente klemborditems gevonden"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "Geen resultaten"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Geen vensterregels geconfigureerd"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Lettertype-instellingen Kladblok"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Kladblok-uittrekpaneel"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Niets"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "Frame openen"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Open KDE Connect op uw telefoon"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Plakken"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Pad naar een videobestand of map met video's"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "Schaduwen pop-outs"
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Loslaten"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Plug-in herladen"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Onthoud laatste gebruiker"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Verwijderen"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Opslaan..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Schaal"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Meldingsregels instellen"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "Instelling"
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Werkblad-apps tonen"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "Meldingen dempen"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Grootte"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Klein"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Samenvatting"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Zonsopgang"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Time-out"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Time-out voor meldingen met kritieke prioriteit"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Titel-regex (optioneel)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Rasterindeling gebruiken"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "IP-locatie gebruiken"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "Gebruikt globaal monospace-lettertype uit Instellingen → Personalisatie"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Gebruikt gedeelde instellingen van Gammaregeling"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Zichtbaarheid"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Visuele effecten"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Widgetbeheer"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Widget-omtrek"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "uitgelicht"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "laatst gezien %1"
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 dzień"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 połączone urządzenie"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": ""
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 minuta"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 minut"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": ""
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": ""
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": ""
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": ""
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": ""
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 minut"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": ""
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": ""
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": ""
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": ""
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Auto (Szeroki)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Automatyczna lokalizacja"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Automatyczne odstępy wyskakujących okienek"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": ""
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Automatycznie czyść po"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Automatyczny zapis..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Automatycznie blokuj ekran, gdy system przygotowuje się do wstrzymania"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": ""
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Konfiguracje pasków"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": ""
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": ""
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Rozmyj tapetę, gdy podgląd niri jest otwarty"
|
||||
},
|
||||
"Body": {
|
||||
"Body": ""
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": ""
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": ""
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Kamera"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Wybierz wyświetlacze na których pokaże się ten widżet"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Steruje kryciem wszystkich okien pop-up, modów i ich warstw zawartości"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": ""
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": ""
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": ""
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Priorytet krytyczny"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": ""
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell jest gotowy do użycia"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Połączone urządzenia"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": ""
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dok i launcher"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Przezroczystość Doka"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Widoczność doku"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": ""
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": ""
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "Edytuj aplikację"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Koniec"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": ""
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": ""
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": ""
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": ""
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": ""
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Instaluj"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Zachowaj zmiany"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": ""
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Ręczny rozmiar odstępu"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Ręczne pokazywanie/ukrywanie"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": ""
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": ""
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "Nowy Jork, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Nowa nazwa grupy..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Brak dostępnych urządzeń jasności"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Bez zmian"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": ""
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": ""
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": ""
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Ustawienia czcionki notatnika"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Wysuwany notatnik"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": ""
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": ""
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": ""
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": ""
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": ""
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": ""
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": ""
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Wczytaj ponownie wtyczkę"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": ""
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Usuń"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": ""
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Skala"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": ""
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": ""
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Pokaż aplikacje z obszaru roboczego"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": ""
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Rozmiar"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": ""
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": ""
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Wschód słońca"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Przekroczono limit czasu"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Przekroczenie limitu czasu powiadomień o krytycznym priorytecie"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": ""
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Użyj układu siatki"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Użyj lokalizacji IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": ""
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": ""
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Widoczność"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": ""
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Zarządzanie widżetami"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Zarys widżetu"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": ""
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": ""
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 dia"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 dispositivo conectado"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 hora e 30 minutos"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 minuto"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 minutos"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": ""
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 minutos"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": ""
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 minutos"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 segundos"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 minutos"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Adicionar por Endereço"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Permitir cliques passarem pelo widget"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": ""
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": ""
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Automático (Largo)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Localização Automática"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Espaçamento Automático de Popup"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": ""
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Auto-Limpeza Depois"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Salvando automáticamente..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Bloquear tela automaticamente quando o sistema é preparado para suspensão"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Automação"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Configurações da Barra"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Sombras da Barra"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": ""
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Desfoque de papel de parede quando a visão geral do niri estiver aberta"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Corpo"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": ""
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": ""
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Câmera"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Escolha quais monitores mostrarão este widget"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Controla a opacidade de todos os popouts, modais e suas camadas de conteúdo"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": ""
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": ""
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": ""
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Prioridade Crítica"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": ""
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell está pronto para uso"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Conexões de dispositivo"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Nomes de dispositivos atualizados"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock & Lançador"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Transparência da Dock"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Visibilidade do Dock"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": ""
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": ""
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "Editar Aplicativo"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Fim"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Aumentar ao Passar o Mouse"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": ""
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": ""
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": ""
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": ""
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Instalar"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Manter Alterações"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": ""
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Espaçamento Manual"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Mostrar/Esconder Manualmente"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "Máximo de Aplicativos em Execução (0 = Ilimitado)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Volume Máximo"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "Nova York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Novo nome de grupo..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Nenhum dispositivo de brilho disponível"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Nenhuma alteração"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Nenhuma entrada recente de área de transferência encontrada"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": ""
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Nenhuma regra de janela configurada"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Configurações da Fonte do Bloco de Notas"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Blocos de Notas Deslizante"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Nada"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": ""
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Abra o KDE Connect em seu telefone"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Colar"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Caminho para um arquivo de vídeo ou pasta de vídeos"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": ""
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Soltar"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Reiniciar Plugin"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Lembrar último usuário"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Remover"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Salvando..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Escala"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Definir regras de notificação"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": ""
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Mostrar Aplicativos da Área de Trabalho Virtual"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": ""
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Tamanho"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Pequeno"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Resumo"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Nascer do Sol"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Tempo Limite Esgotado"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Tempo limite para notificações de prioridade crítica"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Regex de Título (opcional)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Usar Layout em Grade"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Usar Localização do Endereço IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": ""
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Usando configurações compartilhadas do Gamma Control"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Visibilidade"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Efeitos Visuais"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Gerenciamento de Widgets"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Borda de Widgets"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "em destaque"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": ""
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 день"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 устройство подключено"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 час 30 минут"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 минута"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 минут"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 мин"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 минут"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 мин"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 минут"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 секунд"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 минут"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Добавить по адресу"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "Добавить нового пользователя в группу %1, чтобы он мог запустить dms greeter sync --profile."
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "Разрешить"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Разрешить клики проходить сквозь виджет"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "Как минимум один выход должен оставаться включённым"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "Подключить"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Авто (широкий)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Автоматическое Определение Местоположения"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Авто Всплывающее Отступы"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "Включён автоматический режим. Ручной выбор профиля отключён."
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Автоочистка через"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Автосохранение..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Автоматически блокировать экран при подготовке системы к приостановке"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Автоматизация"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Конфигурации бара"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Тени панели"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "Размывать фон за барами, всплывающими окнами, модальными окнами и уведомлениями. Требуется поддержка и настройка композитора."
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Размытие обоев при открытом обзоре Niri"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Заголовок"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "Полужирный"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "Календарь"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Камера"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Выбрать, на каких дисплеях показывать этот виджет"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Контролирует непрозрачность всех всплывающих окон, модальных окон и их слоев контента"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "Управляет контурами вокруг размытых карточек переднего плана, плашек и карточек уведомлений"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "Управляет базовым радиусом размытия и смещением теней"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "Управляет внешним краем окон с размытием по протоколу"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Критический Приоритет"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab: переключить вкладку • Ctrl+S: закрепить/открепить • Shift+Del: очистить всё • Esc: закрыть"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell готов к использованию"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "Сочетание клавиш лаунчера по умолчанию"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": "Открытие по умолчанию"
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Подключения устройств"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Имена устройств обновлены"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Док & Лаунчер"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Прозрачность Дока"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Видимость дока"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "Поля, прозрачность и рамка дока"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "Край, с которого выдвигается лаунчер"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "Изменить приложение"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "Редактировать текст буфера обмена"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Конец"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Увеличивать при наведении"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "Каждые 15 минут"
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "Файловый менеджер"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "Файловый менеджер, используемый для открытия корзины. Выберите «custom», чтобы ввести собственную команду."
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "Вставьте ключ безопасности..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Установить"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Сохранить изменения"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "Продолжайте ввод"
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Ручной размер отступа"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Ручное Отображение/Скрытие"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "Макс запущенных приложений (0 = безлимитно)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Максимальная громкость"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "Нью-Йорк, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Новое название группы..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Устройства яркости недоступны"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Нет изменений"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Недавние записи буфера обмена не найдены"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "Нет результатов"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Правила окон не настроены"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Настройки Шрифта Блокнота"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Выезжающий блокнот"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Ничего"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "Разомкнутая рамка"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Откройте KDE Connect на телефоне"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Вставить"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Путь к видеофайлу или папке с видео"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "Интеграция с Polkit отключена. Управление пользователями требует Polkit для повышения привилегий."
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "Тени всплывающих окон"
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Релиз"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Перезагрузить плагин"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Запомнить последнего пользователя"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Удалить"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Сохранение..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Масштаб"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Установить правила уведомлений"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "Параметр"
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Показать приложения рабочего пространства"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "Приглушить уведомления"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Размер"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Маленький"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Заголовок"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Восход"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Тайм-аут"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Тайм-аут для уведомлений критического приоритета"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Regex заголовка (необязательно)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Использовать макет сетки"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Используемый IP"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "Использует IPC-действие spotlight-bar и всегда открывает минималистичную панель."
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "Используется глобальный моноширинный шрифт из Настройки → Персонализация"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Использование общих настроек из Gamma Control"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Видимость"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Визуальные эффекты"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Управление виджетами"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Контур виджета"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "избранное"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "был в сети %1"
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 dag"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "1 enhet ansluten"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 timme 30 minuter"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 minut"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 minuter"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": ""
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 minuter"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": ""
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 minuter"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 sekunder"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 minuter"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "Lägg till med adress"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "Tillåt klick att passera genom widgeten"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": ""
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "Anslut"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Automatisk (bred)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Automatisk plats"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Automatiska mellanrum för popupfönster"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": ""
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Rensa automatiskt efter"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Sparar automatiskt..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Lås skärmen automatiskt när systemet förbereder sig för strömsparläge"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "Automatisering"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Menyradskonfigurationer"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "Menyradsskuggor"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": ""
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Oskärpa bakgrundsbild när niri-översikten är öppen"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "Brödtext"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": ""
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": ""
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Kamera"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Välj vilka bildskärmar som visar denna widget"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Styr opaciteten för alla popupfönster, dialogrutor och deras innehållslager"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": ""
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "Styr grundoskärperadien och förskjutningen av skuggor"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": ""
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Kritisk prioritet"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": ""
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell är redo att användas"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Enhetsanslutningar"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "Enhetsnamn uppdaterade"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock & Appstartare"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Genomskinlighet på Dock"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Docksynlighet"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": ""
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": ""
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "Redigera app"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Slut"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "Förstora vid hovring"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": ""
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": ""
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": ""
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": ""
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Installera"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Behåll ändringar"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": ""
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Manuell storlek på mellanrum"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Göm och visa manuellt"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "Max aktiva appar (0 = obegränsat)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "Maxvolym"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "Nytt gruppnamn..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Inga ljusstyrkeenheter tillgängliga"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Inga ändringar"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "Inga nyliga urklippsposter hittades"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": ""
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "Inga fönsterregler konfigurerade"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Teckensnittsinställningar för Anteckningar"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Anteckningspanel"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "Inget"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": ""
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "Öppna KDE Connect på din telefon"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "Klistra in"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "Sökväg till en videofil eller mapp med videor"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "Popupfönsterskuggor"
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "Släpp"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Ladda om tillägg"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "Kom ihåg senaste användare"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Ta bort"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "Sparar..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Skala"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "Ange notisregler"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": ""
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Visa appar i en arbetsyta"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": ""
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Storlek"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "Liten"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "Sammanfattning"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Soluppgång"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Tidsgräns överskriden"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Tidsgräns för aviseringar med kritisk prioritet"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "Titelregex (valfritt)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Använd rutnätslayout"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "Använd IP-plats"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": ""
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "Använder delade inställningar från Gammakontroll"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Synlighet"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "Visuella effekter"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Widgethantering"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Widgetkantlinje"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "utvald"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": ""
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 gün"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": ""
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": ""
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 dakika"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 dakika"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": ""
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": ""
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": ""
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": ""
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": ""
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 dakika"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": ""
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": ""
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": ""
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": ""
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": ""
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": ""
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": ""
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "Oto (Geniş)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "Otomatik Konum"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "Otomatik Açılır Pencere Boşlukları"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": ""
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "Sonra Otomatik Sil"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": ""
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "Otomatik kaydetme..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "Sistem askıya alınmaya hazırlanırken ekranı otomatik olarak kilitle"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": ""
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "Bar Ayarları"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": ""
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": ""
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "Niri genel görünümü açıkken duvar kağıdını bulanıklaştır"
|
||||
},
|
||||
"Body": {
|
||||
"Body": ""
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": ""
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": ""
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "Kamera"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": ""
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "Bu widget'ı hangi ekranlarda göstereceğinizi seçin"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "Tüm açılır pencerelerin, modal pencerelerin ve bunların içerik katmanlarının opaklığını kontrol eder."
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": ""
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": ""
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": ""
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "Kritik Öncelik"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": ""
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": ""
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": ""
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": ""
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": ""
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "Cihaz bağlantıları"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": ""
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock & Başlatıcı"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Dock Şeffaflığı"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Dock Görünürlüğü"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": ""
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": ""
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": ""
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": ""
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "Son"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": ""
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "Ethernet"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": ""
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": ""
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": ""
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": ""
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "Yükle"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "Değişiklikleri Tut"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": ""
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "Manuel Boşluk Boyutu"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "Manuel Göster/Gizle"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": ""
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": ""
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "New York, NY"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": ""
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "Parlaklık cihazı yok"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "Değişiklik yok"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": ""
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": ""
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": ""
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": ""
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "Not Defteri Yazı Tipi Ayarları"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "Not Defteri Kaydırma"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": ""
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": ""
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": ""
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": ""
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": ""
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": ""
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": ""
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": ""
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "Eklentiyi Yeniden Yükle"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": ""
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "Kaldır"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": ""
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "Ölçek"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": ""
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": ""
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "Çalışma Alanı Uygulamalarını Göster"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": ""
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "Boyut"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": ""
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": ""
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": ""
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "Gündoğumu"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "Zaman Aşımı"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "Kritik öncelikli bildirimler için zaman aşımı"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": ""
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "Izgara Düzeni Kullan"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "IP Konumunu Kullan"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": ""
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": ""
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": ""
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "Görüş"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": ""
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "Widget Yönetimi"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "Widget Çerçevesi"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": ""
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": ""
|
||||
},
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 天"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "已连接 1 个设备"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 小时 30 分钟"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 分钟"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 分钟"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 分钟"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 分钟"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 分钟"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 分钟"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 秒钟"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 分钟"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "通过地址添加"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": "添加匹配条件"
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "将新用户添加到 %1 组,使其能够运行 dms greeter sync --profile。"
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "允许"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "允许鼠标穿透部件"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "至少应有一个输出保持启用"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "附加"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "自动(宽角)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "自动定位"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "自动弹窗间隙"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "自动模式已开启。手动选择配置已禁用。"
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "自动清除"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": "启动时自动登录"
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "正在自动保存..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "当系统准备挂起时自动锁定屏幕"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "自动化"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "状态栏设置"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "状态栏阴影"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "模糊状态栏、弹窗、模态框以及通知的背景。需要合成器支持与配置。"
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "打开 Niri 概览时模糊壁纸"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "主体"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "粗体"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "日历"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "摄像头"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": "选择需要启动的桌面应用程序或命令"
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "选择要在哪个显示器显示该小部件"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "控制所有弹窗、模态框及其内容层的透明度"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "控制已模糊处理的前景卡片、按钮和通知卡片的轮廓"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "控制阴影的基础模糊半径和偏移量"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "控制协议模糊窗口的边缘"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "紧急优先级"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab:切换标签 • Ctrl+S:固定/取消固定 • Shift+Del:全部清除 • Esc:关闭"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "Dank 状态栏"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell 现已可用"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "默认启动器快捷键"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": "默认打开"
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "设备连接"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "设备名已更新"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "程序坞和启动器"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "程序坞透明度"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "程序坞可见性"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "程序坞边距、透明度和边框"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "启动器滑入侧"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "编辑应用"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "编辑剪贴板文本"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "结束"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "悬停放大"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "以太网"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "每 15 分钟"
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "文件管理器"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "打开回收站的文件管理器。点击“自定义”以输入自定义命令。"
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "请输入安全密钥..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "安装"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "保持更改"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "继续输入"
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "手动设置间隙大小"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "手动显示/隐藏"
|
||||
},
|
||||
@@ -4449,7 +4314,7 @@
|
||||
"Material Colors": "Material 配色"
|
||||
},
|
||||
"Material Design inspired color themes": {
|
||||
"Material Design inspired color themes": "受 Material Design 启发的颜色主题"
|
||||
"Material Design inspired color themes": "受 Material 设计启发的颜色主题"
|
||||
},
|
||||
"Material colors generated from wallpaper": {
|
||||
"Material colors generated from wallpaper": "从壁纸生成的 Material 色彩"
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "最大运行应用数 (0 = 无限制)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "最大音量"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "纽约,美国纽约州"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "新分组名称..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "无可用亮度设备"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "无更改"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "未找到近期剪切板项目"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "无结果"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "未配置窗口规则"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": "噪点"
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "便签字体设置"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "便签侧边栏"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "无"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "打开框架"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "在你的手机上打开 KDE Connect"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "粘贴"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "视频文件路径或包含视频的文件夹"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "Polkit 集成已禁用。用户管理需要 Polkit 提升权限。"
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "弹窗阴影"
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "松开"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "重载插件"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "记住上次的用户"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "移除"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "正在保存..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "缩放"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "设置通知规则"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "设置项"
|
||||
},
|
||||
@@ -6912,7 +6732,7 @@
|
||||
"Show Log Out": "显示注销"
|
||||
},
|
||||
"Show Material Design ripple animations on interactive elements": {
|
||||
"Show Material Design ripple animations on interactive elements": "在交互元素上显示 Material Design 的波纹动画"
|
||||
"Show Material Design ripple animations on interactive elements": "在交互元素上显示 Material 设计的波纹动画"
|
||||
},
|
||||
"Show Media Player": {
|
||||
"Show Media Player": "显示媒体播放器"
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "显示工作区内应用"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "静默通知"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "尺寸"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": "系统启动后直到你退出登录前,都会跳过登录界面的密码验证。锁屏解锁方式不变。同步后在下次重启时生效。"
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "较小"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "概要"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "日出"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "超时"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "关键优先级通知的超时时间"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "标题正则(可选)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "使用网格布局"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "使用 IP 定位"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "使用 spotlight-bar IPC 动作,并始终打开聚焦搜索栏。"
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "正在使用“设置” → “个性化”中的全局等宽字体"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "使用伽马控制的已共享设置"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "可见性"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "视觉效果"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "部件管理"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "部件轮廓"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "精选"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "上次在线:%1"
|
||||
},
|
||||
|
||||
@@ -134,9 +134,6 @@
|
||||
"1 day": {
|
||||
"1 day": "1 天"
|
||||
},
|
||||
"1 day before": {
|
||||
"1 day before": ""
|
||||
},
|
||||
"1 device connected": {
|
||||
"1 device connected": "已連接 1 個裝置"
|
||||
},
|
||||
@@ -146,9 +143,6 @@
|
||||
"1 hour 30 minutes": {
|
||||
"1 hour 30 minutes": "1 小時 30 分鐘"
|
||||
},
|
||||
"1 hour before": {
|
||||
"1 hour before": ""
|
||||
},
|
||||
"1 minute": {
|
||||
"1 minute": "1 分鐘"
|
||||
},
|
||||
@@ -161,9 +155,6 @@
|
||||
"1 task": {
|
||||
"1 task": ""
|
||||
},
|
||||
"10 min before": {
|
||||
"10 min before": ""
|
||||
},
|
||||
"10 minutes": {
|
||||
"10 minutes": "10 分鐘"
|
||||
},
|
||||
@@ -182,9 +173,6 @@
|
||||
"15 min": {
|
||||
"15 min": "15 分鐘"
|
||||
},
|
||||
"15 min before": {
|
||||
"15 min before": ""
|
||||
},
|
||||
"15 minutes": {
|
||||
"15 minutes": "15 分鐘"
|
||||
},
|
||||
@@ -242,9 +230,6 @@
|
||||
"30 min": {
|
||||
"30 min": "30 分鐘"
|
||||
},
|
||||
"30 min before": {
|
||||
"30 min before": ""
|
||||
},
|
||||
"30 minutes": {
|
||||
"30 minutes": "30 分鐘"
|
||||
},
|
||||
@@ -269,9 +254,6 @@
|
||||
"45 seconds": {
|
||||
"45 seconds": "45 秒"
|
||||
},
|
||||
"5 min before": {
|
||||
"5 min before": ""
|
||||
},
|
||||
"5 minutes": {
|
||||
"5 minutes": "5 分鐘"
|
||||
},
|
||||
@@ -467,15 +449,9 @@
|
||||
"Add by Address": {
|
||||
"Add by Address": "按位址新增"
|
||||
},
|
||||
"Add location": {
|
||||
"Add location": ""
|
||||
},
|
||||
"Add match": {
|
||||
"Add match": "新增匹配條件"
|
||||
},
|
||||
"Add notes": {
|
||||
"Add notes": ""
|
||||
},
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": {
|
||||
"Add the new user to the %1 group so they can run dms greeter sync --profile.": "將新使用者加入至 %1 群組,以便他們可以執行 dms greeter sync --profile。"
|
||||
},
|
||||
@@ -524,9 +500,6 @@
|
||||
"Allow": {
|
||||
"Allow": "允許"
|
||||
},
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": {
|
||||
"Allow adjusting device volume by scrolling on the right half of items in the device list": ""
|
||||
},
|
||||
"Allow clicks to pass through the widget": {
|
||||
"Allow clicks to pass through the widget": "允許點擊穿透小工具"
|
||||
},
|
||||
@@ -713,9 +686,6 @@
|
||||
"At least one output must remain enabled": {
|
||||
"At least one output must remain enabled": "至少一個輸出必須保持啟用"
|
||||
},
|
||||
"At start": {
|
||||
"At start": ""
|
||||
},
|
||||
"Attach": {
|
||||
"Attach": "附加"
|
||||
},
|
||||
@@ -806,24 +776,15 @@
|
||||
"Auto (Wide)": {
|
||||
"Auto (Wide)": "自動 (寬)"
|
||||
},
|
||||
"Auto Compositor Gaps": {
|
||||
"Auto Compositor Gaps": ""
|
||||
},
|
||||
"Auto Location": {
|
||||
"Auto Location": "自動定位"
|
||||
},
|
||||
"Auto Overflow": {
|
||||
"Auto Overflow": ""
|
||||
},
|
||||
"Auto Popup Gaps": {
|
||||
"Auto Popup Gaps": "自動調整彈出間隔"
|
||||
},
|
||||
"Auto mode is on. Manual profile selection is disabled.": {
|
||||
"Auto mode is on. Manual profile selection is disabled.": "自動模式已開啟。手動選擇設定檔已停用。"
|
||||
},
|
||||
"Auto saved": {
|
||||
"Auto saved": ""
|
||||
},
|
||||
"Auto-Clear After": {
|
||||
"Auto-Clear After": "自動清除於"
|
||||
},
|
||||
@@ -854,9 +815,6 @@
|
||||
"Auto-login on startup": {
|
||||
"Auto-login on startup": "開機自動登入"
|
||||
},
|
||||
"Auto-save to disk": {
|
||||
"Auto-save to disk": ""
|
||||
},
|
||||
"Auto-saving...": {
|
||||
"Auto-saving...": "自動保存..."
|
||||
},
|
||||
@@ -908,9 +866,6 @@
|
||||
"Automatically lock the screen when the system prepares to suspend": {
|
||||
"Automatically lock the screen when the system prepares to suspend": "睡眠時自動鎖定螢幕"
|
||||
},
|
||||
"Automatically save changes to opened files as you type": {
|
||||
"Automatically save changes to opened files as you type": ""
|
||||
},
|
||||
"Automation": {
|
||||
"Automation": "自動化"
|
||||
},
|
||||
@@ -995,9 +950,6 @@
|
||||
"Bar Configurations": {
|
||||
"Bar Configurations": "欄設定"
|
||||
},
|
||||
"Bar Opacity": {
|
||||
"Bar Opacity": ""
|
||||
},
|
||||
"Bar Shadows": {
|
||||
"Bar Shadows": "列陰影"
|
||||
},
|
||||
@@ -1100,18 +1052,12 @@
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.": "模糊 bar、彈出視窗、模態視窗和通知後面的背景。需要合成器支援和配置。"
|
||||
},
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": {
|
||||
"Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.": ""
|
||||
},
|
||||
"Blur wallpaper when niri overview is open": {
|
||||
"Blur wallpaper when niri overview is open": "當 niri 概覽打開時模糊桌布"
|
||||
},
|
||||
"Body": {
|
||||
"Body": "主體"
|
||||
},
|
||||
"Body Font Size": {
|
||||
"Body Font Size": ""
|
||||
},
|
||||
"Bold": {
|
||||
"Bold": "粗體"
|
||||
},
|
||||
@@ -1232,9 +1178,6 @@
|
||||
"Calendar": {
|
||||
"Calendar": "日曆"
|
||||
},
|
||||
"Calendar Backend": {
|
||||
"Calendar Backend": ""
|
||||
},
|
||||
"Camera": {
|
||||
"Camera": "相機"
|
||||
},
|
||||
@@ -1400,9 +1343,6 @@
|
||||
"Choose whether to launch a desktop app or a command": {
|
||||
"Choose whether to launch a desktop app or a command": "選擇要啟動桌面應用程式還是指令"
|
||||
},
|
||||
"Choose which action buttons appear on clipboard entries": {
|
||||
"Choose which action buttons appear on clipboard entries": ""
|
||||
},
|
||||
"Choose which displays show this widget": {
|
||||
"Choose which displays show this widget": "選擇哪些顯示器顯示此小工具"
|
||||
},
|
||||
@@ -1763,24 +1703,6 @@
|
||||
"Controls opacity of all popouts, modals, and their content layers": {
|
||||
"Controls opacity of all popouts, modals, and their content layers": "控制所有彈出視窗、互動視窗及其內容層的透明度"
|
||||
},
|
||||
"Controls opacity of shell surfaces, popouts, and modals": {
|
||||
"Controls opacity of shell surfaces, popouts, and modals": ""
|
||||
},
|
||||
"Controls opacity of the bar background": {
|
||||
"Controls opacity of the bar background": ""
|
||||
},
|
||||
"Controls opacity of the border": {
|
||||
"Controls opacity of the border": ""
|
||||
},
|
||||
"Controls opacity of the shadow layer": {
|
||||
"Controls opacity of the shadow layer": ""
|
||||
},
|
||||
"Controls opacity of the widget outline": {
|
||||
"Controls opacity of the widget outline": ""
|
||||
},
|
||||
"Controls opacity of widget backgrounds": {
|
||||
"Controls opacity of widget backgrounds": ""
|
||||
},
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": {
|
||||
"Controls outlines around blurred foreground cards, pills, and notification cards": "控制模糊前景卡片、藥丸狀元素和通知卡片周圍的輪廓"
|
||||
},
|
||||
@@ -1790,9 +1712,6 @@
|
||||
"Controls the base blur radius and offset of shadows": {
|
||||
"Controls the base blur radius and offset of shadows": "控制陰影的基本模糊半徑和偏移"
|
||||
},
|
||||
"Controls the opacity of the shadow": {
|
||||
"Controls the opacity of the shadow": ""
|
||||
},
|
||||
"Controls the outer edge of protocol-blurred windows": {
|
||||
"Controls the outer edge of protocol-blurred windows": "控制協定模糊視窗的外邊緣"
|
||||
},
|
||||
@@ -1898,12 +1817,6 @@
|
||||
"Critical Priority": {
|
||||
"Critical Priority": "關鍵優先級"
|
||||
},
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": {
|
||||
"Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close": ""
|
||||
},
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": {
|
||||
"Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find": ""
|
||||
},
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": {
|
||||
"Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close": "Ctrl+Tab:切換分頁 • Ctrl+S:釘選/取消釘選 • Shift+Del:全部清除 • Esc:關閉"
|
||||
},
|
||||
@@ -2099,15 +2012,6 @@
|
||||
"DankBar": {
|
||||
"DankBar": "DankBar"
|
||||
},
|
||||
"DankCalendar": {
|
||||
"DankCalendar": ""
|
||||
},
|
||||
"DankCalendar isn't installed": {
|
||||
"DankCalendar isn't installed": ""
|
||||
},
|
||||
"DankCalendar isn't running": {
|
||||
"DankCalendar isn't running": ""
|
||||
},
|
||||
"DankMaterialShell is ready to use": {
|
||||
"DankMaterialShell is ready to use": "DankMaterialShell 已可使用"
|
||||
},
|
||||
@@ -2174,9 +2078,6 @@
|
||||
"Default Launcher Shortcut": {
|
||||
"Default Launcher Shortcut": "預設啟動器捷徑"
|
||||
},
|
||||
"Default Mode": {
|
||||
"Default Mode": ""
|
||||
},
|
||||
"Default Opens": {
|
||||
"Default Opens": "預設開啟方式"
|
||||
},
|
||||
@@ -2294,9 +2195,6 @@
|
||||
"Device connections": {
|
||||
"Device connections": "裝置連線"
|
||||
},
|
||||
"Device list scroll volume": {
|
||||
"Device list scroll volume": ""
|
||||
},
|
||||
"Device names updated": {
|
||||
"Device names updated": "裝置名稱已更新"
|
||||
},
|
||||
@@ -2471,18 +2369,12 @@
|
||||
"Dock & Launcher": {
|
||||
"Dock & Launcher": "Dock 和啟動器"
|
||||
},
|
||||
"Dock Opacity": {
|
||||
"Dock Opacity": ""
|
||||
},
|
||||
"Dock Transparency": {
|
||||
"Dock Transparency": "Dock 透明度"
|
||||
},
|
||||
"Dock Visibility": {
|
||||
"Dock Visibility": "Dock 可見性"
|
||||
},
|
||||
"Dock margin, opacity, and border": {
|
||||
"Dock margin, opacity, and border": ""
|
||||
},
|
||||
"Dock margin, transparency, and border": {
|
||||
"Dock margin, transparency, and border": "Dock 邊距、透明度和邊框"
|
||||
},
|
||||
@@ -2573,9 +2465,6 @@
|
||||
"Edge the launcher slides from": {
|
||||
"Edge the launcher slides from": "啟動器滑出的邊緣"
|
||||
},
|
||||
"Edit": {
|
||||
"Edit": ""
|
||||
},
|
||||
"Edit App": {
|
||||
"Edit App": "編輯應用程式"
|
||||
},
|
||||
@@ -2591,9 +2480,6 @@
|
||||
"Edit clipboard text": {
|
||||
"Edit clipboard text": "編輯剪貼簿文字"
|
||||
},
|
||||
"Edit event": {
|
||||
"Edit event": ""
|
||||
},
|
||||
"Editing changes on %1": {
|
||||
"Editing changes on %1": ""
|
||||
},
|
||||
@@ -2711,9 +2597,6 @@
|
||||
"End": {
|
||||
"End": "結束"
|
||||
},
|
||||
"End must be after start": {
|
||||
"End must be after start": ""
|
||||
},
|
||||
"Enlarge on Hover": {
|
||||
"Enlarge on Hover": "懸停時放大"
|
||||
},
|
||||
@@ -2798,9 +2681,6 @@
|
||||
"Ethernet": {
|
||||
"Ethernet": "乙太網路"
|
||||
},
|
||||
"Event title": {
|
||||
"Event title": ""
|
||||
},
|
||||
"Every 15 minutes": {
|
||||
"Every 15 minutes": "每 15 分鐘"
|
||||
},
|
||||
@@ -3149,9 +3029,6 @@
|
||||
"File Manager": {
|
||||
"File Manager": "檔案管理員"
|
||||
},
|
||||
"File changed on disk": {
|
||||
"File changed on disk": ""
|
||||
},
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": {
|
||||
"File manager used to open the trash. Pick \"custom\" to enter your own command.": "檔案管理器用於開啟垃圾桶。選擇「自訂」以輸入您自己的指令。"
|
||||
},
|
||||
@@ -3962,9 +3839,6 @@
|
||||
"Insert your security key...": {
|
||||
"Insert your security key...": "插入您的安全金鑰..."
|
||||
},
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": {
|
||||
"Inset the Notepad from screen edges using the compositor's configured gaps": ""
|
||||
},
|
||||
"Install": {
|
||||
"Install": "安裝"
|
||||
},
|
||||
@@ -4073,12 +3947,6 @@
|
||||
"Keep Changes": {
|
||||
"Keep Changes": "保留變更"
|
||||
},
|
||||
"Keep My Edits": {
|
||||
"Keep My Edits": ""
|
||||
},
|
||||
"Keep in Bar": {
|
||||
"Keep in Bar": ""
|
||||
},
|
||||
"Keep typing": {
|
||||
"Keep typing": "繼續輸入"
|
||||
},
|
||||
@@ -4406,9 +4274,6 @@
|
||||
"Manual Gap Size": {
|
||||
"Manual Gap Size": "手動調整間隔"
|
||||
},
|
||||
"Manual Gaps": {
|
||||
"Manual Gaps": ""
|
||||
},
|
||||
"Manual Show/Hide": {
|
||||
"Manual Show/Hide": "手動顯示/隱藏"
|
||||
},
|
||||
@@ -4493,9 +4358,6 @@
|
||||
"Max Running Apps (0 = Unlimited)": {
|
||||
"Max Running Apps (0 = Unlimited)": "最多執行中應用程式 (0 = 無限制)"
|
||||
},
|
||||
"Max Visible": {
|
||||
"Max Visible": ""
|
||||
},
|
||||
"Max Volume": {
|
||||
"Max Volume": "最大音量"
|
||||
},
|
||||
@@ -4844,9 +4706,6 @@
|
||||
"New York, NY": {
|
||||
"New York, NY": "紐約"
|
||||
},
|
||||
"New event": {
|
||||
"New event": ""
|
||||
},
|
||||
"New group name...": {
|
||||
"New group name...": "新群組名稱..."
|
||||
},
|
||||
@@ -4982,9 +4841,6 @@
|
||||
"No brightness devices available": {
|
||||
"No brightness devices available": "沒有可用的亮度裝置"
|
||||
},
|
||||
"No calendar source available": {
|
||||
"No calendar source available": ""
|
||||
},
|
||||
"No changes": {
|
||||
"No changes": "無更改"
|
||||
},
|
||||
@@ -5111,9 +4967,6 @@
|
||||
"No recent clipboard entries found": {
|
||||
"No recent clipboard entries found": "找不到近期剪貼簿項目"
|
||||
},
|
||||
"No reminder": {
|
||||
"No reminder": ""
|
||||
},
|
||||
"No results": {
|
||||
"No results": "無結果"
|
||||
},
|
||||
@@ -5177,9 +5030,6 @@
|
||||
"No window rules configured": {
|
||||
"No window rules configured": "未設定任何視窗規則"
|
||||
},
|
||||
"No writable calendar available": {
|
||||
"No writable calendar available": ""
|
||||
},
|
||||
"Noise": {
|
||||
"Noise": "雜訊"
|
||||
},
|
||||
@@ -5240,15 +5090,9 @@
|
||||
"Notepad Font Settings": {
|
||||
"Notepad Font Settings": "筆記本字體設定"
|
||||
},
|
||||
"Notepad Settings": {
|
||||
"Notepad Settings": ""
|
||||
},
|
||||
"Notepad Slideout": {
|
||||
"Notepad Slideout": "記事本滑出"
|
||||
},
|
||||
"Notes": {
|
||||
"Notes": ""
|
||||
},
|
||||
"Nothing": {
|
||||
"Nothing": "無內容"
|
||||
},
|
||||
@@ -5372,9 +5216,6 @@
|
||||
"Open Frame": {
|
||||
"Open Frame": "打開框架"
|
||||
},
|
||||
"Open From": {
|
||||
"Open From": ""
|
||||
},
|
||||
"Open KDE Connect on your phone": {
|
||||
"Open KDE Connect on your phone": "在您的手機上開啟 KDE Connect"
|
||||
},
|
||||
@@ -5618,9 +5459,6 @@
|
||||
"Paste": {
|
||||
"Paste": "貼上"
|
||||
},
|
||||
"Path copied to clipboard": {
|
||||
"Path copied to clipboard": ""
|
||||
},
|
||||
"Path to a video file or folder containing videos": {
|
||||
"Path to a video file or folder containing videos": "影片檔案或包含影片的資料夾路徑"
|
||||
},
|
||||
@@ -5807,9 +5645,6 @@
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": {
|
||||
"Polkit integration is disabled. User management requires Polkit to elevate privileges.": "Polkit 整合已停用。使用者管理需要 Polkit 來提升權限。"
|
||||
},
|
||||
"Popout": {
|
||||
"Popout": ""
|
||||
},
|
||||
"Popout Shadows": {
|
||||
"Popout Shadows": "彈出陰影"
|
||||
},
|
||||
@@ -6131,9 +5966,6 @@
|
||||
"Release": {
|
||||
"Release": "放開"
|
||||
},
|
||||
"Reload From Disk": {
|
||||
"Reload From Disk": ""
|
||||
},
|
||||
"Reload Plugin": {
|
||||
"Reload Plugin": "重新載入插件"
|
||||
},
|
||||
@@ -6155,9 +5987,6 @@
|
||||
"Remember last user": {
|
||||
"Remember last user": "記住上次用戶"
|
||||
},
|
||||
"Reminder": {
|
||||
"Reminder": ""
|
||||
},
|
||||
"Remove": {
|
||||
"Remove": "刪除"
|
||||
},
|
||||
@@ -6458,9 +6287,6 @@
|
||||
"Saving...": {
|
||||
"Saving...": "儲存中..."
|
||||
},
|
||||
"Saving…": {
|
||||
"Saving…": ""
|
||||
},
|
||||
"Scale": {
|
||||
"Scale": "縮放"
|
||||
},
|
||||
@@ -6749,12 +6575,6 @@
|
||||
"Set notification rules": {
|
||||
"Set notification rules": "設定通知規則"
|
||||
},
|
||||
"Set the font size for notification body text (htmlBody)": {
|
||||
"Set the font size for notification body text (htmlBody)": ""
|
||||
},
|
||||
"Set the font size for notification summary text": {
|
||||
"Set the font size for notification summary text": ""
|
||||
},
|
||||
"Setting": {
|
||||
"Setting": "設定"
|
||||
},
|
||||
@@ -7013,9 +6833,6 @@
|
||||
"Show Workspace Apps": {
|
||||
"Show Workspace Apps": "顯示工作區應用程式"
|
||||
},
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": {
|
||||
"Show a bar that drains as the popup's auto-dismiss timer runs": ""
|
||||
},
|
||||
"Show all 9 tags instead of only occupied tags": {
|
||||
"Show all 9 tags instead of only occupied tags": ""
|
||||
},
|
||||
@@ -7157,9 +6974,6 @@
|
||||
"Silence notifications": {
|
||||
"Silence notifications": "靜音通知"
|
||||
},
|
||||
"Single-Line Popup": {
|
||||
"Single-Line Popup": ""
|
||||
},
|
||||
"Size": {
|
||||
"Size": "大小"
|
||||
},
|
||||
@@ -7184,9 +6998,6 @@
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": {
|
||||
"Skip the greeter password after boot until you sign out. Lock screen unlock is unchanged. Takes effect on the next reboot after sync.": "開機後跳過歡迎介面密碼,直到您登出為止。鎖定螢幕解鎖不受影響。同步後於下次重新開機時生效。"
|
||||
},
|
||||
"Slideout": {
|
||||
"Slideout": ""
|
||||
},
|
||||
"Small": {
|
||||
"Small": "小"
|
||||
},
|
||||
@@ -7313,9 +7124,6 @@
|
||||
"Summary": {
|
||||
"Summary": "摘要"
|
||||
},
|
||||
"Summary Font Size": {
|
||||
"Summary Font Size": ""
|
||||
},
|
||||
"Sunrise": {
|
||||
"Sunrise": "日出"
|
||||
},
|
||||
@@ -7664,9 +7472,6 @@
|
||||
"Timed Out": {
|
||||
"Timed Out": "逾時"
|
||||
},
|
||||
"Timeout Progress Bar": {
|
||||
"Timeout Progress Bar": ""
|
||||
},
|
||||
"Timeout for critical priority notifications": {
|
||||
"Timeout for critical priority notifications": "緊急優先級通知的超時"
|
||||
},
|
||||
@@ -7688,9 +7493,6 @@
|
||||
"Title (optional)": {
|
||||
"Title (optional)": ""
|
||||
},
|
||||
"Title is required": {
|
||||
"Title is required": ""
|
||||
},
|
||||
"Title regex (optional)": {
|
||||
"Title regex (optional)": "標題正規表達式 (選用)"
|
||||
},
|
||||
@@ -8030,9 +7832,6 @@
|
||||
"Use Grid Layout": {
|
||||
"Use Grid Layout": "使用網格佈局"
|
||||
},
|
||||
"Use HH:MM time format": {
|
||||
"Use HH:MM time format": ""
|
||||
},
|
||||
"Use IP Location": {
|
||||
"Use IP Location": "使用 IP 位置"
|
||||
},
|
||||
@@ -8171,15 +7970,9 @@
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": {
|
||||
"Uses the spotlight-bar IPC action and always opens the minimal bar.": "使用 spotlight-bar IPC 動作並始終開啟簡約工具列。"
|
||||
},
|
||||
"Using DankCalendar%1": {
|
||||
"Using DankCalendar%1": ""
|
||||
},
|
||||
"Using global monospace font from Settings → Personalization": {
|
||||
"Using global monospace font from Settings → Personalization": "使用來自「設定」→「個人化」的全域等寬字體"
|
||||
},
|
||||
"Using khal": {
|
||||
"Using khal": ""
|
||||
},
|
||||
"Using shared settings from Gamma Control": {
|
||||
"Using shared settings from Gamma Control": "使用 Gamma Control 的共享設定"
|
||||
},
|
||||
@@ -8267,9 +8060,6 @@
|
||||
"Visibility": {
|
||||
"Visibility": "能見度"
|
||||
},
|
||||
"Visible Entry Actions": {
|
||||
"Visible Entry Actions": ""
|
||||
},
|
||||
"Visual Effects": {
|
||||
"Visual Effects": "視覺效果"
|
||||
},
|
||||
@@ -8393,9 +8183,6 @@
|
||||
"Widget Management": {
|
||||
"Widget Management": "部件管理"
|
||||
},
|
||||
"Widget Opacity": {
|
||||
"Widget Opacity": ""
|
||||
},
|
||||
"Widget Outline": {
|
||||
"Widget Outline": "部件外框"
|
||||
},
|
||||
@@ -8639,9 +8426,6 @@
|
||||
"featured": {
|
||||
"featured": "精選"
|
||||
},
|
||||
"khal": {
|
||||
"khal": ""
|
||||
},
|
||||
"last seen %1": {
|
||||
"last seen %1": "上次看到 %1"
|
||||
},
|
||||
|
||||
@@ -58,7 +58,6 @@
|
||||
"targetable",
|
||||
"wallpaper"
|
||||
],
|
||||
"icon": "blur_on",
|
||||
"description": "Enable compositor-targetable blur layer (namespace: dms:blurwallpaper). Requires manual niri configuration.",
|
||||
"conditionKey": "isNiri"
|
||||
},
|
||||
@@ -428,28 +427,6 @@
|
||||
],
|
||||
"description": "Automatically determine your location using your IP address"
|
||||
},
|
||||
{
|
||||
"section": "calendarBackend",
|
||||
"label": "Calendar Backend",
|
||||
"tabIndex": 1,
|
||||
"category": "Time & Weather",
|
||||
"keywords": [
|
||||
"backend",
|
||||
"calendar",
|
||||
"clock",
|
||||
"daemon",
|
||||
"dankcalendar",
|
||||
"date",
|
||||
"day",
|
||||
"events",
|
||||
"forecast",
|
||||
"khal",
|
||||
"month",
|
||||
"time",
|
||||
"weather",
|
||||
"year"
|
||||
]
|
||||
},
|
||||
{
|
||||
"section": "dateFormat",
|
||||
"label": "Date Format",
|
||||
@@ -750,6 +727,21 @@
|
||||
],
|
||||
"icon": "dashboard"
|
||||
},
|
||||
{
|
||||
"section": "_tab_3",
|
||||
"label": "Dank Bar",
|
||||
"tabIndex": 3,
|
||||
"category": "Dank Bar",
|
||||
"keywords": [
|
||||
"bar",
|
||||
"dank",
|
||||
"panel",
|
||||
"statusbar",
|
||||
"taskbar",
|
||||
"topbar"
|
||||
],
|
||||
"icon": "toolbar"
|
||||
},
|
||||
{
|
||||
"section": "barDisplay",
|
||||
"label": "Display Assignment",
|
||||
@@ -785,19 +777,30 @@
|
||||
"icon": "vertical_align_center"
|
||||
},
|
||||
{
|
||||
"section": "_tab_3",
|
||||
"label": "Settings",
|
||||
"section": "barSpacing",
|
||||
"label": "Spacing",
|
||||
"tabIndex": 3,
|
||||
"category": "Dank Bar",
|
||||
"keywords": [
|
||||
"bar",
|
||||
"between",
|
||||
"dank",
|
||||
"edges",
|
||||
"gap",
|
||||
"gaps",
|
||||
"margin",
|
||||
"margins",
|
||||
"padding",
|
||||
"panel",
|
||||
"settings",
|
||||
"screen",
|
||||
"space",
|
||||
"spacing",
|
||||
"statusbar",
|
||||
"taskbar",
|
||||
"topbar"
|
||||
],
|
||||
"icon": "tune"
|
||||
"icon": "space_bar",
|
||||
"description": "Space between the bar and screen edges"
|
||||
},
|
||||
{
|
||||
"section": "barUseOverlayLayer",
|
||||
@@ -1525,19 +1528,6 @@
|
||||
"windows"
|
||||
]
|
||||
},
|
||||
{
|
||||
"section": "dockTransparency",
|
||||
"label": "Opacity",
|
||||
"tabIndex": 5,
|
||||
"category": "Dock",
|
||||
"keywords": [
|
||||
"dock",
|
||||
"launcher bar",
|
||||
"opacity",
|
||||
"taskbar"
|
||||
],
|
||||
"icon": "opacity"
|
||||
},
|
||||
{
|
||||
"section": "dockTrashFileManager",
|
||||
"label": "Open Trash With",
|
||||
@@ -1755,6 +1745,23 @@
|
||||
],
|
||||
"icon": "space_bar"
|
||||
},
|
||||
{
|
||||
"section": "dockTransparency",
|
||||
"label": "Transparency",
|
||||
"tabIndex": 5,
|
||||
"category": "Dock",
|
||||
"keywords": [
|
||||
"alpha",
|
||||
"dock",
|
||||
"launcher bar",
|
||||
"opacity",
|
||||
"taskbar",
|
||||
"translucent",
|
||||
"transparency",
|
||||
"transparent"
|
||||
],
|
||||
"icon": "opacity"
|
||||
},
|
||||
{
|
||||
"section": "dockTrash",
|
||||
"label": "Trash",
|
||||
@@ -1791,6 +1798,21 @@
|
||||
],
|
||||
"description": "Place the dock on the Wayland overlay layer"
|
||||
},
|
||||
{
|
||||
"section": "_tab_6",
|
||||
"label": "Appearance",
|
||||
"tabIndex": 6,
|
||||
"category": "Dank Bar",
|
||||
"keywords": [
|
||||
"appearance",
|
||||
"bar",
|
||||
"dank",
|
||||
"panel",
|
||||
"statusbar",
|
||||
"topbar"
|
||||
],
|
||||
"icon": "palette"
|
||||
},
|
||||
{
|
||||
"section": "barBorder",
|
||||
"label": "Border",
|
||||
@@ -1960,25 +1982,6 @@
|
||||
],
|
||||
"description": "Use a fixed shadow direction for this bar"
|
||||
},
|
||||
{
|
||||
"section": "barTransparency",
|
||||
"label": "Opacity",
|
||||
"tabIndex": 6,
|
||||
"category": "Dank Bar",
|
||||
"keywords": [
|
||||
"background",
|
||||
"bar",
|
||||
"controls",
|
||||
"dank",
|
||||
"opacity",
|
||||
"panel",
|
||||
"statusbar",
|
||||
"taskbar",
|
||||
"topbar"
|
||||
],
|
||||
"icon": "opacity",
|
||||
"description": "Controls opacity of the bar background"
|
||||
},
|
||||
{
|
||||
"section": "barShadow",
|
||||
"label": "Shadow Override",
|
||||
@@ -1999,32 +2002,6 @@
|
||||
"icon": "layers",
|
||||
"description": "Override the global shadow with per-bar settings"
|
||||
},
|
||||
{
|
||||
"section": "barSpacing",
|
||||
"label": "Spacing",
|
||||
"tabIndex": 6,
|
||||
"category": "Dank Bar",
|
||||
"keywords": [
|
||||
"bar",
|
||||
"between",
|
||||
"dank",
|
||||
"edges",
|
||||
"gap",
|
||||
"gaps",
|
||||
"margin",
|
||||
"margins",
|
||||
"padding",
|
||||
"panel",
|
||||
"screen",
|
||||
"space",
|
||||
"spacing",
|
||||
"statusbar",
|
||||
"taskbar",
|
||||
"topbar"
|
||||
],
|
||||
"icon": "space_bar",
|
||||
"description": "Space between the bar and screen edges"
|
||||
},
|
||||
{
|
||||
"section": "trayIconTint",
|
||||
"label": "System Tray Icon Tint",
|
||||
@@ -2053,6 +2030,28 @@
|
||||
"icon": "filter_b_and_w",
|
||||
"description": "Controls how much original icon color is removed before applying tint"
|
||||
},
|
||||
{
|
||||
"section": "barTransparency",
|
||||
"label": "Transparency",
|
||||
"tabIndex": 6,
|
||||
"category": "Dank Bar",
|
||||
"keywords": [
|
||||
"alpha",
|
||||
"background",
|
||||
"bar",
|
||||
"dank",
|
||||
"opacity",
|
||||
"panel",
|
||||
"statusbar",
|
||||
"taskbar",
|
||||
"topbar",
|
||||
"translucent",
|
||||
"transparency",
|
||||
"transparent"
|
||||
],
|
||||
"icon": "opacity",
|
||||
"description": "Opacity of the bar background"
|
||||
},
|
||||
{
|
||||
"section": "barWidgetOutline",
|
||||
"label": "Widget Outline",
|
||||
@@ -2125,25 +2124,6 @@
|
||||
"icon": "wifi",
|
||||
"conditionKey": "dmsConnected"
|
||||
},
|
||||
{
|
||||
"section": "networkStatus",
|
||||
"label": "Network Status",
|
||||
"tabIndex": 7,
|
||||
"category": "Network",
|
||||
"keywords": [
|
||||
"connection",
|
||||
"connectivity",
|
||||
"ethernet",
|
||||
"internet",
|
||||
"network",
|
||||
"online",
|
||||
"status",
|
||||
"wi-fi",
|
||||
"wifi",
|
||||
"wireless"
|
||||
],
|
||||
"icon": "lan"
|
||||
},
|
||||
{
|
||||
"section": "_tab_8",
|
||||
"label": "Printers",
|
||||
@@ -3812,6 +3792,7 @@
|
||||
"tabIndex": 10,
|
||||
"category": "Theme & Colors",
|
||||
"keywords": [
|
||||
"alpha",
|
||||
"appearance",
|
||||
"colors",
|
||||
"controls",
|
||||
@@ -3823,9 +3804,11 @@
|
||||
"shadow",
|
||||
"style",
|
||||
"theme",
|
||||
"transparency"
|
||||
"translucent",
|
||||
"transparency",
|
||||
"transparent"
|
||||
],
|
||||
"description": "Controls the opacity of the shadow"
|
||||
"description": "Controls the transparency of the shadow"
|
||||
},
|
||||
{
|
||||
"section": "m3ElevationEnabled",
|
||||
@@ -3850,34 +3833,8 @@
|
||||
"style",
|
||||
"theme"
|
||||
],
|
||||
"icon": "layers",
|
||||
"description": "Material inspired shadows and elevation on modals, popouts, and dialogs"
|
||||
},
|
||||
{
|
||||
"section": "popupTransparency",
|
||||
"label": "Surface Opacity",
|
||||
"tabIndex": 10,
|
||||
"category": "Theme & Colors",
|
||||
"keywords": [
|
||||
"appearance",
|
||||
"colors",
|
||||
"controls",
|
||||
"look",
|
||||
"modal",
|
||||
"modals",
|
||||
"opacity",
|
||||
"popouts",
|
||||
"popup",
|
||||
"scheme",
|
||||
"shell",
|
||||
"style",
|
||||
"surface",
|
||||
"surfaces",
|
||||
"theme",
|
||||
"transparency"
|
||||
],
|
||||
"description": "Controls opacity of shell surfaces, popouts, and modals"
|
||||
},
|
||||
{
|
||||
"section": "syncModeWithPortal",
|
||||
"label": "Sync Mode with Portal",
|
||||
@@ -4009,6 +3966,35 @@
|
||||
"icon": "palette",
|
||||
"description": "Select the palette algorithm used for wallpaper-based colors"
|
||||
},
|
||||
{
|
||||
"section": "popupTransparency",
|
||||
"label": "Transparency",
|
||||
"tabIndex": 10,
|
||||
"category": "Theme & Colors",
|
||||
"keywords": [
|
||||
"alpha",
|
||||
"appearance",
|
||||
"colors",
|
||||
"content",
|
||||
"controls",
|
||||
"layers",
|
||||
"look",
|
||||
"modal",
|
||||
"modals",
|
||||
"opacity",
|
||||
"popouts",
|
||||
"popup",
|
||||
"scheme",
|
||||
"style",
|
||||
"surface",
|
||||
"their",
|
||||
"theme",
|
||||
"translucent",
|
||||
"transparency",
|
||||
"transparent"
|
||||
],
|
||||
"description": "Controls opacity of all popouts, modals, and their content layers"
|
||||
},
|
||||
{
|
||||
"section": "matugenTemplateVscode",
|
||||
"label": "VS Code",
|
||||
@@ -4577,27 +4563,6 @@
|
||||
],
|
||||
"description": "Automatically lock the screen when DMS starts"
|
||||
},
|
||||
{
|
||||
"section": "lockBeforeSuspend",
|
||||
"label": "Lock before suspend",
|
||||
"tabIndex": 11,
|
||||
"category": "Lock Screen",
|
||||
"keywords": [
|
||||
"automatic",
|
||||
"automatically",
|
||||
"before",
|
||||
"lock",
|
||||
"login",
|
||||
"password",
|
||||
"prepares",
|
||||
"screen",
|
||||
"security",
|
||||
"sleep",
|
||||
"suspend",
|
||||
"system"
|
||||
],
|
||||
"description": "Automatically lock the screen when the system prepares to suspend"
|
||||
},
|
||||
{
|
||||
"section": "lockScreenNotificationMode",
|
||||
"label": "Notification Display",
|
||||
@@ -5505,26 +5470,6 @@
|
||||
],
|
||||
"icon": "dashboard"
|
||||
},
|
||||
{
|
||||
"section": "notificationBodyFontSize",
|
||||
"label": "Body Font Size",
|
||||
"tabIndex": 17,
|
||||
"category": "Notifications",
|
||||
"keywords": [
|
||||
"alert",
|
||||
"alerts",
|
||||
"body",
|
||||
"font",
|
||||
"messages",
|
||||
"notif",
|
||||
"notification",
|
||||
"notifications",
|
||||
"size",
|
||||
"text",
|
||||
"toast"
|
||||
],
|
||||
"description": "Set the font size for notification body text (htmlBody)"
|
||||
},
|
||||
{
|
||||
"section": "notificationCompactMode",
|
||||
"label": "Compact",
|
||||
@@ -5922,19 +5867,22 @@
|
||||
"keywords": [
|
||||
"alert",
|
||||
"alerts",
|
||||
"font",
|
||||
"appear",
|
||||
"choose",
|
||||
"location",
|
||||
"messages",
|
||||
"notif",
|
||||
"notification",
|
||||
"notifications",
|
||||
"popup",
|
||||
"popups",
|
||||
"size",
|
||||
"summary",
|
||||
"text",
|
||||
"toast"
|
||||
"position",
|
||||
"screen",
|
||||
"toast",
|
||||
"where"
|
||||
],
|
||||
"icon": "notifications",
|
||||
"description": "Set the font size for notification summary text"
|
||||
"description": "Choose where notification popups appear on screen"
|
||||
},
|
||||
{
|
||||
"section": "notificationRules",
|
||||
@@ -6084,26 +6032,6 @@
|
||||
],
|
||||
"description": "Hide notification content until expanded; popups show collapsed by default"
|
||||
},
|
||||
{
|
||||
"section": "notificationSummaryFontSize",
|
||||
"label": "Summary Font Size",
|
||||
"tabIndex": 17,
|
||||
"category": "Notifications",
|
||||
"keywords": [
|
||||
"alert",
|
||||
"alerts",
|
||||
"font",
|
||||
"messages",
|
||||
"notif",
|
||||
"notification",
|
||||
"notifications",
|
||||
"size",
|
||||
"summary",
|
||||
"text",
|
||||
"toast"
|
||||
],
|
||||
"description": "Set the font size for notification summary text"
|
||||
},
|
||||
{
|
||||
"section": "notificationDedupeEnabled",
|
||||
"label": "Suppress Duplicate Notifications",
|
||||
@@ -6126,32 +6054,6 @@
|
||||
"toast"
|
||||
]
|
||||
},
|
||||
{
|
||||
"section": "notificationShowTimeoutBar",
|
||||
"label": "Timeout Progress Bar",
|
||||
"tabIndex": 17,
|
||||
"category": "Notifications",
|
||||
"keywords": [
|
||||
"alerts",
|
||||
"bar",
|
||||
"countdown",
|
||||
"drains",
|
||||
"messages",
|
||||
"notification",
|
||||
"notifications",
|
||||
"panel",
|
||||
"popup",
|
||||
"progress",
|
||||
"show",
|
||||
"statusbar",
|
||||
"taskbar",
|
||||
"timeout",
|
||||
"timer",
|
||||
"toast",
|
||||
"topbar"
|
||||
],
|
||||
"description": "Show a bar that drains as the popup"
|
||||
},
|
||||
{
|
||||
"section": "osdAlwaysShowValue",
|
||||
"label": "Always Show Percentage",
|
||||
@@ -6376,6 +6278,25 @@
|
||||
],
|
||||
"description": "Choose where on-screen displays appear on screen"
|
||||
},
|
||||
{
|
||||
"section": "_tab_18",
|
||||
"label": "On-screen Displays",
|
||||
"tabIndex": 18,
|
||||
"category": "On-screen Displays",
|
||||
"keywords": [
|
||||
"displays",
|
||||
"indicator",
|
||||
"monitor",
|
||||
"monitors",
|
||||
"osd",
|
||||
"output",
|
||||
"outputs",
|
||||
"popup",
|
||||
"screen",
|
||||
"screens"
|
||||
],
|
||||
"icon": "tune"
|
||||
},
|
||||
{
|
||||
"section": "osd",
|
||||
"label": "On-screen Displays",
|
||||
@@ -6511,6 +6432,20 @@
|
||||
"icon": "tune",
|
||||
"description": "Open a terminal and run a custom command instead of the in-shell upgrade flow."
|
||||
},
|
||||
{
|
||||
"section": "_tab_20",
|
||||
"label": "System Updater",
|
||||
"tabIndex": 20,
|
||||
"category": "System Updater",
|
||||
"keywords": [
|
||||
"packages",
|
||||
"system",
|
||||
"updater",
|
||||
"updates",
|
||||
"upgrade"
|
||||
],
|
||||
"icon": "refresh"
|
||||
},
|
||||
{
|
||||
"section": "systemUpdater",
|
||||
"label": "System Updater",
|
||||
@@ -6762,6 +6697,27 @@
|
||||
"icon": "schedule",
|
||||
"description": "Gradually fade the screen before locking with a configurable grace period"
|
||||
},
|
||||
{
|
||||
"section": "lockBeforeSuspend",
|
||||
"label": "Lock before suspend",
|
||||
"tabIndex": 21,
|
||||
"category": "Power & Sleep",
|
||||
"keywords": [
|
||||
"automatically",
|
||||
"before",
|
||||
"energy",
|
||||
"lock",
|
||||
"power",
|
||||
"prepares",
|
||||
"screen",
|
||||
"security",
|
||||
"shutdown",
|
||||
"sleep",
|
||||
"suspend",
|
||||
"system"
|
||||
],
|
||||
"description": "Automatically lock the screen when the system prepares to suspend"
|
||||
},
|
||||
{
|
||||
"section": "fadeToLockGracePeriod",
|
||||
"label": "Lock fade grace period",
|
||||
@@ -7163,36 +7119,6 @@
|
||||
],
|
||||
"description": "Maximum number of entries that can be saved"
|
||||
},
|
||||
{
|
||||
"section": "clipboardVisibleEntryActions",
|
||||
"label": "Visible Entry Actions",
|
||||
"tabIndex": 23,
|
||||
"category": "System",
|
||||
"keywords": [
|
||||
"action",
|
||||
"actions",
|
||||
"appear",
|
||||
"buttons",
|
||||
"choose",
|
||||
"clipboard",
|
||||
"cliphist",
|
||||
"copy",
|
||||
"delete",
|
||||
"density",
|
||||
"edit",
|
||||
"entries",
|
||||
"entry",
|
||||
"hide",
|
||||
"history",
|
||||
"linux",
|
||||
"os",
|
||||
"paste",
|
||||
"pin",
|
||||
"system",
|
||||
"visible"
|
||||
],
|
||||
"description": "Choose which action buttons appear on clipboard entries"
|
||||
},
|
||||
{
|
||||
"section": "_tab_24",
|
||||
"label": "Displays",
|
||||
@@ -7295,8 +7221,7 @@
|
||||
"screen",
|
||||
"widgets"
|
||||
],
|
||||
"icon": "widgets",
|
||||
"conditionKey": "dmsConnected"
|
||||
"icon": "widgets"
|
||||
},
|
||||
{
|
||||
"section": "_tab_27",
|
||||
@@ -7965,6 +7890,19 @@
|
||||
],
|
||||
"description": "Reveal the arcs where surfaces meet the frame"
|
||||
},
|
||||
{
|
||||
"section": "_tab_33",
|
||||
"label": "Frame",
|
||||
"tabIndex": 33,
|
||||
"category": "Frame",
|
||||
"keywords": [
|
||||
"border",
|
||||
"decoration",
|
||||
"frame",
|
||||
"window"
|
||||
],
|
||||
"icon": "frame_source"
|
||||
},
|
||||
{
|
||||
"section": "frameEnabled",
|
||||
"label": "Frame",
|
||||
@@ -8461,7 +8399,7 @@
|
||||
"topbar",
|
||||
"window"
|
||||
],
|
||||
"icon": "layers",
|
||||
"icon": "crop_square",
|
||||
"description": "Use custom gaps instead of bar spacing",
|
||||
"conditionKey": "isNiri"
|
||||
},
|
||||
@@ -8843,6 +8781,23 @@
|
||||
],
|
||||
"description": "Space between windows"
|
||||
},
|
||||
{
|
||||
"section": "_tab_38",
|
||||
"label": "Window Rules",
|
||||
"tabIndex": 38,
|
||||
"category": "Applications",
|
||||
"keywords": [
|
||||
"applications",
|
||||
"apps",
|
||||
"floating",
|
||||
"matching",
|
||||
"programs",
|
||||
"rules",
|
||||
"window"
|
||||
],
|
||||
"icon": "select_window",
|
||||
"conditionKey": "windowRulesCapable"
|
||||
},
|
||||
{
|
||||
"section": "windowRules",
|
||||
"label": "Window Rules",
|
||||
@@ -8865,56 +8820,5 @@
|
||||
"icon": "select_window",
|
||||
"description": "Define compositor rules for window behavior",
|
||||
"conditionKey": "windowRulesCapable"
|
||||
},
|
||||
{
|
||||
"section": "networkEthernet",
|
||||
"label": "Ethernet",
|
||||
"tabIndex": 39,
|
||||
"category": "Network",
|
||||
"keywords": [
|
||||
"adapters",
|
||||
"connection",
|
||||
"connectivity",
|
||||
"ethernet",
|
||||
"network",
|
||||
"online",
|
||||
"wired"
|
||||
],
|
||||
"icon": "settings_ethernet"
|
||||
},
|
||||
{
|
||||
"section": "networkWifi",
|
||||
"label": "WiFi",
|
||||
"tabIndex": 40,
|
||||
"category": "Network",
|
||||
"keywords": [
|
||||
"adapter",
|
||||
"connectivity",
|
||||
"network",
|
||||
"online",
|
||||
"radio",
|
||||
"ssid",
|
||||
"wi-fi",
|
||||
"wifi",
|
||||
"wireless"
|
||||
],
|
||||
"icon": "wifi"
|
||||
},
|
||||
{
|
||||
"section": "networkVpn",
|
||||
"label": "VPN",
|
||||
"tabIndex": 41,
|
||||
"category": "Network",
|
||||
"keywords": [
|
||||
"connectivity",
|
||||
"import",
|
||||
"network",
|
||||
"online",
|
||||
"openvpn",
|
||||
"profiles",
|
||||
"vpn",
|
||||
"wireguard"
|
||||
],
|
||||
"icon": "vpn_key"
|
||||
}
|
||||
]
|
||||
|
||||
@@ -314,13 +314,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "1 day before",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "1 device connected",
|
||||
"translation": "",
|
||||
@@ -342,13 +335,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "1 hour before",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "1 minute",
|
||||
"translation": "",
|
||||
@@ -377,13 +363,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "10 min before",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "10 minutes",
|
||||
"translation": "",
|
||||
@@ -426,13 +405,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "15 min before",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "15 minutes",
|
||||
"translation": "",
|
||||
@@ -566,13 +538,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "30 min before",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "30 minutes",
|
||||
"translation": "",
|
||||
@@ -629,13 +594,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "5 min before",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "5 minutes",
|
||||
"translation": "",
|
||||
@@ -1091,13 +1049,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Add location",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Add match",
|
||||
"translation": "",
|
||||
@@ -1105,13 +1056,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Add notes",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Add the new user to the %1 group so they can run dms greeter sync --profile.",
|
||||
"translation": "",
|
||||
@@ -1224,13 +1168,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Allow adjusting device volume by scrolling on the right half of items in the device list",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Allow clicks to pass through the widget",
|
||||
"translation": "",
|
||||
@@ -1665,13 +1602,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "At start",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Attach",
|
||||
"translation": "",
|
||||
@@ -1864,7 +1794,7 @@
|
||||
{
|
||||
"term": "Auto",
|
||||
"translation": "",
|
||||
"context": "calendar backend option | theme category option",
|
||||
"context": "theme category option",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
@@ -1882,13 +1812,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Auto Compositor Gaps",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Auto Location",
|
||||
"translation": "",
|
||||
@@ -1896,13 +1819,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Auto Overflow",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Auto Popup Gaps",
|
||||
"translation": "",
|
||||
@@ -1917,13 +1833,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Auto saved",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Auto-Clear After",
|
||||
"translation": "",
|
||||
@@ -1995,7 +1904,7 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Auto-save to disk",
|
||||
"term": "Auto-saving...",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -2113,13 +2022,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Automatically save changes to opened files as you type",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Automation",
|
||||
"translation": "",
|
||||
@@ -2317,14 +2219,14 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Bar Opacity",
|
||||
"term": "Bar Shadows",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Bar Shadows",
|
||||
"term": "Bar Transparency",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -2548,7 +2450,7 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Blur the background behind bars, popouts, modals, and notifications. Requires compositor support. Adjust Opacity accordingly.",
|
||||
"term": "Blur the background behind bars, popouts, modals, and notifications. Requires compositor support and configuration.",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -2568,13 +2470,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Body Font Size",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Bold",
|
||||
"translation": "",
|
||||
@@ -2855,13 +2750,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Calendar Backend",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Camera",
|
||||
"translation": "",
|
||||
@@ -3247,13 +3135,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Choose which action buttons appear on clipboard entries",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Choose which displays show this widget",
|
||||
"translation": "",
|
||||
@@ -4088,42 +3969,7 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls opacity of shell surfaces, popouts, and modals",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls opacity of the bar background",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls opacity of the border",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls opacity of the shadow layer",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls opacity of the widget outline",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls opacity of widget backgrounds",
|
||||
"term": "Controls opacity of all popouts, modals, and their content layers",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -4151,14 +3997,14 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls the opacity of the shadow",
|
||||
"term": "Controls the outer edge of protocol-blurred windows",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Controls the outer edge of protocol-blurred windows",
|
||||
"term": "Controls the transparency of the shadow",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -4395,20 +4241,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Ctrl+A: Select All • Ctrl+P: Preview • Enter/Shift+Enter: Find Next/Previous • Esc: Close",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Ctrl+S: Save • Ctrl+O: Open • Ctrl+N: New • Ctrl+F: Find",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Ctrl+Tab: Switch Tab • Ctrl+S: Pin/Unpin • Shift+Del: Clear All • Esc: Close",
|
||||
"translation": "",
|
||||
@@ -4661,6 +4493,13 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Custom Transparency",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Custom command and terminal params are split on whitespace; paths with spaces will break.",
|
||||
"translation": "",
|
||||
@@ -4857,27 +4696,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "DankCalendar",
|
||||
"translation": "",
|
||||
"context": "calendar backend option",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "DankCalendar isn't installed",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "DankCalendar isn't running",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "DankMaterialShell is ready to use",
|
||||
"translation": "",
|
||||
@@ -5032,13 +4850,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Default Mode",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Default Opens",
|
||||
"translation": "",
|
||||
@@ -5312,13 +5123,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Device list scroll volume",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Device names updated",
|
||||
"translation": "",
|
||||
@@ -5726,7 +5530,7 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Dock Opacity",
|
||||
"term": "Dock Transparency",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -5740,7 +5544,7 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Dock margin, opacity, and border",
|
||||
"term": "Dock margin, transparency, and border",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -5949,13 +5753,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Edit",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Edit App",
|
||||
"translation": "",
|
||||
@@ -5991,13 +5788,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Edit event",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Editing changes on %1",
|
||||
"translation": "",
|
||||
@@ -6271,13 +6061,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "End must be after start",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Enlarge on Hover",
|
||||
"translation": "",
|
||||
@@ -6474,13 +6257,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Event title",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Every 15 minutes",
|
||||
"translation": "",
|
||||
@@ -7293,13 +7069,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "File changed on disk",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "File manager used to open the trash. Pick \"custom\" to enter your own command.",
|
||||
"translation": "",
|
||||
@@ -9190,13 +8959,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Inset the Notepad from screen edges using the compositor's configured gaps",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Install",
|
||||
"translation": "",
|
||||
@@ -9449,20 +9211,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Keep My Edits",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Keep in Bar",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Keep typing",
|
||||
"translation": "",
|
||||
@@ -10226,13 +9974,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Manual Gaps",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Manual Show/Hide",
|
||||
"translation": "",
|
||||
@@ -10429,13 +10170,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Max Visible",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Max Volume",
|
||||
"translation": "",
|
||||
@@ -11248,13 +10982,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "New event",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "New group name...",
|
||||
"translation": "",
|
||||
@@ -11570,13 +11297,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "No calendar source available",
|
||||
"translation": "",
|
||||
"context": "calendar backend status",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "No changes",
|
||||
"translation": "",
|
||||
@@ -11871,13 +11591,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "No reminder",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "No results",
|
||||
"translation": "",
|
||||
@@ -12025,13 +11738,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "No writable calendar available",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Noise",
|
||||
"translation": "",
|
||||
@@ -12166,7 +11872,7 @@
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Notepad Settings",
|
||||
"term": "Notepad Font Settings",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
@@ -12179,13 +11885,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Notes",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Nothing",
|
||||
"translation": "",
|
||||
@@ -12424,6 +12123,20 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Opacity of the bar background",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Opacity of widget backgrounds",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Opaque",
|
||||
"translation": "",
|
||||
@@ -12459,13 +12172,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Open From",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Open KDE Connect on your phone",
|
||||
"translation": "",
|
||||
@@ -13033,13 +12739,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Path copied to clipboard",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Path to a video file or folder containing videos",
|
||||
"translation": "",
|
||||
@@ -13474,13 +13173,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Popout",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Popout Shadows",
|
||||
"translation": "",
|
||||
@@ -14230,13 +13922,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Reload From Disk",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Reload Plugin",
|
||||
"translation": "",
|
||||
@@ -14286,13 +13971,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Reminder",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Remove",
|
||||
"translation": "",
|
||||
@@ -14993,13 +14671,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Saving…",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Scale",
|
||||
"translation": "",
|
||||
@@ -15672,20 +15343,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Set the font size for notification body text (htmlBody)",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Set the font size for notification summary text",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Setting",
|
||||
"translation": "",
|
||||
@@ -16288,13 +15945,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Show a bar that drains as the popup's auto-dismiss timer runs",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Show all 9 tags instead of only occupied tags",
|
||||
"translation": "",
|
||||
@@ -16624,13 +16274,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Single-Line Popup",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Size",
|
||||
"translation": "",
|
||||
@@ -16687,13 +16330,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Slideout",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Small",
|
||||
"translation": "",
|
||||
@@ -16988,13 +16624,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Summary Font Size",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Sunrise",
|
||||
"translation": "",
|
||||
@@ -17807,13 +17436,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Timeout Progress Bar",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Timeout for critical priority notifications",
|
||||
"translation": "",
|
||||
@@ -17863,13 +17485,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Title is required",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Title regex (optional)",
|
||||
"translation": "",
|
||||
@@ -18094,6 +17709,27 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Transparency of the border",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Transparency of the shadow layer",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Transparency of the widget outline",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Trash",
|
||||
"translation": "",
|
||||
@@ -18486,6 +18122,13 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Unsaved note...",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Unset",
|
||||
"translation": "",
|
||||
@@ -18633,13 +18276,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Use HH:MM time format",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Use IP Location",
|
||||
"translation": "",
|
||||
@@ -18962,13 +18598,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Using DankCalendar%1",
|
||||
"translation": "",
|
||||
"context": "calendar backend status",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Using global monospace font from Settings → Personalization",
|
||||
"translation": "",
|
||||
@@ -18976,13 +18605,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Using khal",
|
||||
"translation": "",
|
||||
"context": "calendar backend status",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Using shared settings from Gamma Control",
|
||||
"translation": "",
|
||||
@@ -19186,13 +18808,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Visible Entry Actions",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Visual Effects",
|
||||
"translation": "",
|
||||
@@ -19480,13 +19095,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Widget Opacity",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Widget Outline",
|
||||
"translation": "",
|
||||
@@ -19508,6 +19116,13 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Widget Transparency",
|
||||
"translation": "",
|
||||
"context": "",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "Widget added",
|
||||
"translation": "",
|
||||
@@ -20047,13 +19662,6 @@
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "khal",
|
||||
"translation": "",
|
||||
"context": "calendar backend option",
|
||||
"reference": "",
|
||||
"comment": ""
|
||||
},
|
||||
{
|
||||
"term": "last seen %1",
|
||||
"translation": "",
|
||||
|
||||
Reference in New Issue
Block a user