From b6a34cbc47fcef2f0b8b828314290f4e1270dae0 Mon Sep 17 00:00:00 2001 From: 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> Date: Wed, 28 May 2025 22:03:05 +0800 Subject: internal: move weather into service Also fix not escaping city properly --- modules/dashboard/dash/Weather.qml | 28 ++++++---------------------- 1 file changed, 6 insertions(+), 22 deletions(-) (limited to 'modules/dashboard') diff --git a/modules/dashboard/dash/Weather.qml b/modules/dashboard/dash/Weather.qml index 99947f7..489444f 100644 --- a/modules/dashboard/dash/Weather.qml +++ b/modules/dashboard/dash/Weather.qml @@ -8,29 +8,13 @@ import QtQuick Item { id: root - property string icon - property string description - property real temperature - anchors.centerIn: parent implicitWidth: icon.implicitWidth + info.implicitWidth + info.anchors.leftMargin - onVisibleChanged: wttrProc.running = true - - Process { - id: wttrProc - - running: true - command: ["fish", "-c", `curl "https://wttr.in/$(curl ipinfo.io | jq -r '.city' | string replace ' ' '%20')?format=j1" | jq -c '.current_condition[0] | {code: .weatherCode, desc: .weatherDesc[0].value, temp: .temp_C}'`] - stdout: SplitParser { - onRead: data => { - const json = JSON.parse(data); - root.icon = Icons.getWeatherIcon(json.code); - root.description = json.desc; - root.temperature = parseFloat(json.temp); - } - } + onVisibleChanged: { + if (visible) + Weather.reload(); } MaterialIcon { @@ -40,7 +24,7 @@ Item { anchors.left: parent.left animate: true - text: root.icon || "cloud_alert" + text: Weather.icon || "cloud_alert" color: Colours.palette.m3secondary font.pointSize: Appearance.font.size.extraLarge * 2 font.variableAxes: ({ @@ -61,7 +45,7 @@ Item { anchors.horizontalCenter: parent.horizontalCenter animate: true - text: `${root.temperature}°C` + text: `${Weather.temperature}°C` color: Colours.palette.m3primary font.pointSize: Appearance.font.size.extraLarge font.weight: 500 @@ -71,7 +55,7 @@ Item { anchors.horizontalCenter: parent.horizontalCenter animate: true - text: root.description || qsTr("No weather") + text: Weather.description || qsTr("No weather") elide: Text.ElideRight width: Math.min(implicitWidth, root.parent.width - icon.implicitWidth - info.anchors.leftMargin - Appearance.padding.large * 2) -- cgit v1.2.3-freya